我的文件夹中有一些文本文件,我需要使用python遍历这些文件并从中提取数据。为了获得所有的路径名,我使用了glob.glob(),除了我需要排除任何名称中包含'ER‘的文件。在环顾四周后,我找到了!_命令,但是它不起作用。下面是我的代码,仍然返回'ER‘文件。
files = glob.glob('*[!ER]*.txt')发布于 2020-01-29 01:56:57
你有你的文件列表,你可以使用列表理解来过滤和删除任何包含'ER‘的文件。
files = [f for f in files if 'ER' not in f]发布于 2020-01-30 09:21:48
还有其他库可以做排除。例如,wcmatch (完全公开,我是它的作者)允许您使用排除模式(当通过一个标志启用时)。排除模式与正常模式一起给出,它将过滤返回的文件列表:
from wcmatch import glob
glob.glob(['*.txt', '!*ER*.txt'], flags=glob.N)下面是一个真实的例子:
from wcmatch import glob
>>> glob.glob(['*.md'], flags=glob.N)
['LICENSE.md', 'README.md']
>>> glob.glob(['*.md', '!*EA*.md'], flags=glob.N)
['LICENSE.md']https://stackoverflow.com/questions/59954358
复制相似问题