Ми можемо отримати список файлів всередині папки у файловій системі за допомогою різних стандартних функцій бібліотеки 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)
}
}
- Використання filepath.Walk
path/filepath
Пакет забезпечує зручний спосіб для сканування всіх файлів в каталозі, він буде автоматично сканувати кожен підкаталоги в каталозі.
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
}
- Використання ioutil.ReadDir
ioutil.ReadDir
читає каталог, названий dirname, і повертає список записів каталогів, відсортованих за іменем файлу.
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
Readdir зчитує вміст каталогу, пов'язаного з файлом, і повертає фрагмент до n значень FileInfo, як би повернув Lstat, у порядку каталогу. Подальші дзвінки в той самий файл нададуть додаткові дані 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
}
Результати порівняння.
Дізнайтеся більше про цю публікацію в блозі