Możemy uzyskać listę plików w folderze w systemie plików, używając różnych standardowych funkcji biblioteki golang.
- filepath.Walk
- ioutil.ReadDir
- os.File.Readdir
package main
import (
"fmt"
"io/ioutil"
"log"
"os"
"path/filepath"
)
func main() {
var (
root string
files []string
err error
)
root := "/home/manigandan/golang/samples"
// filepath.Walk
files, err = FilePathWalkDir(root)
if err != nil {
panic(err)
}
// ioutil.ReadDir
files, err = IOReadDir(root)
if err != nil {
panic(err)
}
//os.File.Readdir
files, err = OSReadDir(root)
if err != nil {
panic(err)
}
for _, file := range files {
fmt.Println(file)
}
}
- Korzystanie z pliku filepath.Walk
path/filepath
Pakiet zapewnia wygodny sposób, aby skanować wszystkie pliki w katalogu, zostanie ona automatycznie skanować każdy podkatalogów w katalogu.
func FilePathWalkDir(root string) ([]string, error) {
var files []string
err := filepath.Walk(root, func(path string, info os.FileInfo, err error) error {
if !info.IsDir() {
files = append(files, path)
}
return nil
})
return files, err
}
- Korzystanie z ioutil.ReadDir
ioutil.ReadDir
odczytuje katalog o nazwie dirname i zwraca listę pozycji katalogu posortowanych według nazwy pliku.
func IOReadDir(root string) ([]string, error) {
var files []string
fileInfo, err := ioutil.ReadDir(root)
if err != nil {
return files, err
}
for _, file := range fileInfo {
files = append(files, file.Name())
}
return files, nil
}
- Korzystanie z os.File.Readdir
Readdir odczytuje zawartość katalogu powiązanego z plikiem i zwraca kawałek do n wartości FileInfo, tak jak zwracałby to Lstat, w kolejności katalogów. Kolejne wywołania tego samego pliku przyniosą dalsze FileInfos.
func OSReadDir(root string) ([]string, error) {
var files []string
f, err := os.Open(root)
if err != nil {
return files, err
}
fileInfo, err := f.Readdir(-1)
f.Close()
if err != nil {
return files, err
}
for _, file := range fileInfo {
files = append(files, file.Name())
}
return files, nil
}
Wyniki testu.
Uzyskaj więcej informacji na temat tego posta na blogu