Çeşitli golang standart kütüphane işlevlerini kullanarak dosya sistemindeki bir klasör içindeki dosyaların bir listesini alabiliriz.
- 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)
}
}
- Filepath.Walk kullanma
path/filepath
Paket, otomatik olarak dizindeki her bir alt dizinleri tarayacak bir dizindeki tüm dosyaları taramak için kullanışlı bir yol sağlar.
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
}
- İoutil.ReadDir kullanma
ioutil.ReadDir
dirname adlı dizini okur ve dosya adına göre sıralanmış dizin girişlerinin listesini döndürür.
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
}
- Os.File.Readdir kullanma
Readdir, dosya ile ilişkilendirilmiş dizinin içeriğini okur ve Lstat tarafından döndürüleceği gibi, n dizine kadar n FileInfo değerine kadar bir dilim döndürür. Aynı dosyaya yapılan sonraki çağrılar daha fazla FileInfos verecektir.
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
}
Deney sonuçları.
Bu Blog Yayını hakkında daha fazla bilgi edinin