我有一个包含一些文件名(位置)的列表,我要做的是从列表位置中删除所有元素。
条件:若文件名以排除列表中的任何字符串开头,则不要打印该文件名。

locations = ['/data/mybackup/data/fil1',
            '/data/mybackup/data/fil2',
            '/data/mybackup/data/fil3',
            '/data/mybackup/song/fil1',
            '/data/mybackup/song/fil2',
            '/data/mybackup/song/fil3',
            '/data/archive/song/fil1',
            '/data/archive/song/fil2',
            '/data/archive/song/fil3',
            '/data/archive/data/fil1',
            '/local/archive/data/fil2',
            '/local/archive/data/fil3',
            '/ebboks/wordpress/fil1',
            '/ebooks/wordpress/fil2',
            '/ebooks/wordpress/fil3']

excludes = [  '/data/archive/', '/data' , '/ebooks/'   ]

for location in locations:
  for exclude in excludes:
    if not location.startswith(exclude):
      print(location)
    break

结果:
/data/mybackup/data/fil1
/data/mybackup/data/fil2
/data/mybackup/data/fil3
/data/mybackup/song/fil1
/data/mybackup/song/fil2
/data/mybackup/song/fil3
/local/archive/data/fil2
/local/archive/data/fil3
/ebboks/wordpress/fil1
/ebooks/wordpress/fil2
/ebooks/wordpress/fil3

我的结果仍然有以'/data'开头的文件名
我的代码怎么了?

最佳答案

str.startswith接受要检查的参数的tuple,这样就避免了要检查的附加循环和排序比较的问题,因此可以使用:

exc = tuple(excludes)
# Or start with: excludes = ('/data/archive/', '/data' , '/ebooks/') instead
for location in locations:
    if not location.startswith(exc):
        print(location)

它给你:
/local/archive/data/fil2
/local/archive/data/fil3
/ebboks/wordpress/fil1

10-06 09:16
查看更多