Rekursives Suchen von Dateien mit verschiedenen Methoden
Bei der rekursiven Suche nach Dateien in einer Verzeichnisstruktur ist glob() möglicherweise nicht die effizienteste oder umfassender Ansatz. In diesem Artikel werden alternative Methoden zum Erreichen einer rekursiven Dateiauflistung untersucht:
pathlib.Path().rglob()
Das Pathlib-Modul führt pathlib.Path().rglob( ), das rekursiv nach passenden Dateien sucht. Beispiel:
from pathlib import Path for path in Path('src').rglob('*.c'): print(path.name)
glob.glob() mit recursive=True
Für Python-Versionen vor 3.5 bietet glob.glob() eine rekursive Option. Beispiel:
from glob import glob for filename in glob('src/**/*.c', recursive=True): print(filename)
os.walk()
Für ältere Python-Versionen bietet os.walk() in Kombination mit fnmatch.filter() eine rekursive Suche. Beispiel:
import fnmatch import os matches = [] for root, dirnames, filenames in os.walk('src'): for filename in fnmatch.filter(filenames, '*.c'): matches.append(os.path.join(root, filename))
Die Methode os.walk() durchläuft alle Unterverzeichnisse, während fnmatch.filter() einen einfachen Mustervergleich anwendet. Dieser Ansatz kann für große Verzeichnisse aufgrund des geringeren Overheads im Vergleich zu pathlib.
effizienter seinDas obige ist der detaillierte Inhalt vonWas ist der beste Weg, Dateien in Python rekursiv zu finden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!