以下代码如何用Pythonic的方式编写?
extensions = ['.mp3','.avi']
file_name = 'test.mp3'
for extension in extensions:
if file_name.endswith(extension):
#do stuff
我记得好像可以避免明确声明 for
循环并将其写在 if
条件中。这是真的吗?
虽然不是众所周知,str.endswith 也接受元组作为参数。你不需要循环。
>>> 'test.mp3'.endswith(('.mp3', '.avi'))
True
import string; str.endswith(tuple(string.ascii_lowercase))
- Alex Willisonendswith
函数只接受元组作为参数,适用于 Python 2.5 及以上版本。 - Akash Singh只需使用:
if file_name.endswith(tuple(extensions)):
sample = "alexis has the control"
matched_strings = filter(sample.endswith, ["trol", "ol", "troll"])
print matched_strings
['trol', 'ol']
有两种方法:正则表达式和字符串(str)方法。
字符串方法通常更快(~2倍)。
import re, timeit
p = re.compile('.*(.mp3|.avi)$', re.IGNORECASE)
file_name = 'test.mp3'
print(bool(t.match(file_name))
%timeit bool(t.match(file_name)
每次循环平均需要792纳秒,标准差为1.83纳秒(在7组,每组1000000次循环的情况下)。
file_name = 'test.mp3'
extensions = ('.mp3','.avi')
print(file_name.lower().endswith(extensions))
%timeit file_name.lower().endswith(extensions)
每个循环的平均时间为274纳秒±4.22纳秒(7次运行的平均值和标准偏差,共1000000次循环)
我在寻找其它东西时无意中发现了这个。
我建议使用os
包中的方法。这是因为您可以使其更加通用,以弥补任何奇怪的情况。
您可以这样做:
import os
the_file = 'aaaa/bbbb/ccc.ddd'
extensions_list = ['ddd', 'eee', 'fff']
if os.path.splitext(the_file)[-1] in extensions_list:
# Do your thing.
我有这个:
def has_extension(filename, extension):
ext = "." + extension
if filename.endswith(ext):
return True
else:
return False
return filename.endswith(ext)
吗? :P - Mr_and_Mrs_D另一种可能性是利用IN语句:
extensions = ['.mp3','.avi']
file_name = 'test.mp3'
if "." in file_name and file_name[file_name.rindex("."):] in extensions:
print(True)
index
应该改为 rindex
。 - NeverHopeless
if any((file_name.endswith(ext) for ext in extensions))
。 - sapht