例如:在C:\TDDOWNLOAD目录下有a.txt、b.txt两个文件,另有\sub1子文件夹,C:\TDDOWNLOAD\sub1下又有c.txt、d.txt两个文件。
1. os.walk
os.walk()返回一个三元素的tuple:当前路径、子文件夹名称、文件列表。
>>> import os >>> def fun( path ): ... for root, dirs, files in os.walk( path ): ... for fn in files: ... print root, fn ... >>> fun( r‘C:\TDDOWNLOAD‘ ) C:\TDDOWNLOAD a.txt C:\TDDOWNLOAD b.txt C:\TDDOWNLOAD\sub1 c.txt C:\TDDOWNLOAD\sub1 d.txt >>>
2. glob.glob
glob.glob()只接受一个参数,这个参数既代有路径,又代有匹配模式,返回值为一个列表。注意,glob.glob()无法直接穿透子文件夹,需要自己处理:
>>> def fun( path ): ... for fn in glob.glob( path + os.sep + ‘*‘ ): # ‘*‘代表匹配所有文件 ... if os.path.isdir( fn ): # 如果结果为文件夹 ... fun( fn ) # 递归 ... else: ... print fn ... >>> fun( r‘C:\TDDOWNLOAD‘ ) C:\TDDOWNLOAD\a.txt C:\TDDOWNLOAD\b.txt C:\TDDOWNLOAD\sub1\c.txt C:\TDDOWNLOAD\sub1\d.txt >>>
‘*‘为匹配模式,代表匹配所有文件,只有这样才能将子文件夹查出来,以便递归深入,探查下一层的文件。
时间: 2024-10-06 13:52:18