директории

This commit is contained in:
badkaktus 2019-10-11 15:42:02 +03:00
parent c764388d93
commit d41d978a14
2 changed files with 26 additions and 26 deletions

View File

@ -59,7 +59,7 @@ Epoch
Запись файлов (Writing Files) Запись файлов (Writing Files)
Строковые фильтры (Line Filters) Строковые фильтры (Line Filters)
Пути к файлам (File Paths) Пути к файлам (File Paths)
Directories Директории (Directories)
Temporary Files and Directories Temporary Files and Directories
Testing Testing
Command-Line Arguments Command-Line Arguments

View File

@ -1,5 +1,5 @@
// Go has several useful functions for working with // Go имеет несколько полезных функций для работы
// *directories* in the file system. // с *каталогами* в файловой системе.
package main package main
@ -18,18 +18,18 @@ func check(e error) {
func main() { func main() {
// Create a new sub-directory in the current working // Создадим новую суб-директорию в текущей рабочей
// directory. // папке.
err := os.Mkdir("subdir", 0755) err := os.Mkdir("subdir", 0755)
check(err) check(err)
// When creating temporary directories, it's good // Когда мы создаем временную директорию, хорошим
// practice to `defer` their removal. `os.RemoveAll` // тоном является удалить ее через `defer`.
// will delete a whole directory tree (similarly to // `os.RemoveAll` удалит директорию и все, что в ней
// `rm -rf`). // находится (по аналогии с `rm -rf`).
defer os.RemoveAll("subdir") defer os.RemoveAll("subdir")
// Helper function to create a new empty file. // Функция-помощник для создания нового пустого файла.
createEmptyFile := func(name string) { createEmptyFile := func(name string) {
d := []byte("") d := []byte("")
check(ioutil.WriteFile(name, d, 0644)) check(ioutil.WriteFile(name, d, 0644))
@ -37,9 +37,9 @@ func main() {
createEmptyFile("subdir/file1") createEmptyFile("subdir/file1")
// We can create a hierarchy of directories, including // Мы можем создать иерархию из директорий, включая все
// parents with `MkdirAll`. This is similar to the // родительские, с помощью `MkdirAll`. Это является аналогом
// command-line `mkdir -p`. // команды `mkdir -p`.
err = os.MkdirAll("subdir/parent/child", 0755) err = os.MkdirAll("subdir/parent/child", 0755)
check(err) check(err)
@ -47,8 +47,8 @@ func main() {
createEmptyFile("subdir/parent/file3") createEmptyFile("subdir/parent/file3")
createEmptyFile("subdir/parent/child/file4") createEmptyFile("subdir/parent/child/file4")
// `ReadDir` lists directory contents, returning a // `ReadDir` перечисляет содержимое каталогов,
// slice of `os.FileInfo` objects. // возвращая срез объектов `os.FileInfo`.
c, err := ioutil.ReadDir("subdir/parent") c, err := ioutil.ReadDir("subdir/parent")
check(err) check(err)
@ -57,13 +57,14 @@ func main() {
fmt.Println(" ", entry.Name(), entry.IsDir()) fmt.Println(" ", entry.Name(), entry.IsDir())
} }
// `Chdir` lets us change the current working directory, // `Chdir` позволяет изменить текущую рабочую
// similarly to `cd`. // директорию, по аналогии с `cd`.
err = os.Chdir("subdir/parent/child") err = os.Chdir("subdir/parent/child")
check(err) check(err)
// Now we'll see the contents of `subdir/parent/child` // Теперь мы увидим содержимое директории
// when listing the *current* directory. // `subdir/parent/child`, когда запросим листинг
// *текущей* директории.
c, err = ioutil.ReadDir(".") c, err = ioutil.ReadDir(".")
check(err) check(err)
@ -72,20 +73,19 @@ func main() {
fmt.Println(" ", entry.Name(), entry.IsDir()) fmt.Println(" ", entry.Name(), entry.IsDir())
} }
// `cd` back to where we started. // Вернемся в начало
err = os.Chdir("../../..") err = os.Chdir("../../..")
check(err) check(err)
// We can also visit a directory *recursively*, // Мы также можем *рекурсивно* обойти каталог, включая
// including all its sub-directories. `Walk` accepts // все его подкаталоги. `Walk` принимает функцию обратного
// a callback function to handle every file or // вызова для обработки каждого файла или каталога,
// directory visited. // которые посетили.
fmt.Println("Visiting subdir") fmt.Println("Visiting subdir")
err = filepath.Walk("subdir", visit) err = filepath.Walk("subdir", visit)
} }
// `visit` is called for every file or directory found // `visit` вызывается для каждого найденного элемента в `filepath.Walk`.
// recursively by `filepath.Walk`.
func visit(p string, info os.FileInfo, err error) error { func visit(p string, info os.FileInfo, err error) error {
if err != nil { if err != nil {
return err return err