EDIT : Genug Leute haben diese Antwort noch getroffen, dass ich dachte, ich würde sie für die Go1-API aktualisieren. Dies ist ein funktionierendes Beispiel für filepath.Walk () . Das Original ist unten.
package main
import (
"path/filepath"
"os"
"flag"
"fmt"
)
func visit(path string, f os.FileInfo, err error) error {
fmt.Printf("Visited: %s\n", path)
return nil
}
func main() {
flag.Parse()
root := flag.Arg(0)
err := filepath.Walk(root, visit)
fmt.Printf("filepath.Walk() returned %v\n", err)
}
Bitte beachten Sie, dass filepath.Walk den Verzeichnisbaum rekursiv durchläuft.
Dies ist ein Beispiellauf:
$ mkdir -p dir1/dir2
$ touch dir1/file1 dir1/dir2/file2
$ go run walk.go dir1
Visited: dir1
Visited: dir1/dir2
Visited: dir1/dir2/file2
Visited: dir1/file1
filepath.Walk() returned <nil>
ORIGINAL ANTWORT FOLGT: Die Benutzeroberfläche für das Gehen von Dateipfaden hat sich seit dem wöchentlichen 2011-09-16 geändert, siehe http://groups.google.com/group/golang-nuts/msg/e304dd9cf196a218 . Der folgende Code wird in naher Zukunft nicht für Release-Versionen von GO funktionieren.
Es gibt tatsächlich eine Funktion in der Standardbibliothek, nur dafür: filepath.Walk .
package main
import (
"path/filepath"
"os"
"flag"
)
type visitor int
// THIS CODE NO LONGER WORKS, PLEASE SEE ABOVE
func (v visitor) VisitDir(path string, f *os.FileInfo) bool {
println(path)
return true
}
func (v visitor) VisitFile(path string, f *os.FileInfo) {
println(path)
}
func main() {
root := flag.Arg(0)
filepath.Walk(root, visitor(0), nil)
}