glob模块是一个文件操作相关模块,用它可以查找符合要求的文件,支持通配符操作。
通配符 功能
* 匹配0或多个字符
** 匹配所有文件,目录,子目录和子目录里面的文件 (3.5版本新增)
? 匹配一个字符,这里与正则表达式? (正则?匹配前面表达式0次或者1次)
[] 匹配指定范围内的字符,如: [1-9]匹配1至9内的字符
[!] 匹配不在指定范围内的字符
两个主要方法如下。
1. glob方法:
glob模块的主要方法就是glob,该方法返回所有匹配的文件路径列表(list);
该方法需要一个参数用来指定匹配的路径字符串(字符串可以为绝对路径也可以为相对路径),其返回的文件名只包括当前目录里的文件名,不包括子文件夹里的文件。
1.当前路径下所有py文件 for fname in glob.glob("**/*.py",recursive=True): print(fname) 2.当前路径文件tmp下py文件 for fname in glob.glob("./tmp/*.py"): print(fname) 3.单字通配符?,当前路径文件下以file开头后有一个字符的py文件 for fname in glob.glob("./file?.py"): print(fname) 4.范围通配符[],当前路径文件下以file开头后一个数字符的py文件 for fname in glob.glob("./file[0-9].py"): print(fname) 5.范围通配符[],当前路径文件下以file开头后一个非数字符的py文件 for fname in glob.glob("./file[!0-9].py"): print(fname) windowns下 file = glob.glob(r'D:\logs\*\*')
2、iglob方法
返回一个迭代器iterator,执行效率更高
1.当前路径文件tmp下py文件,使用iglob,返回迭代器效率更高 >>> glob.iglob('./tmp/*.py') <generator object _iglob at 0x7fc140780cd0> for fname in glob.iglob("./tmp/*.py"): print(fname)
其他
1.转移字符 specials = '?*[' for char in specials: pattern = '**/*' + glob.escape(char) + '.txt' print('Searching for: {!r}'.format(pattern)) for name in sorted(glob.glob(pattern,recursive=True)): print(name)