在python中,有没有更好的方法
将字符串参数化为正则表达式
而不是像这样手动操作:
test = 'flobalob'
names = ['a', 'b', 'c']
for name in names:
regexp = "%s" % (name)
print regexp, re.search(regexp, test)
这个noddy示例依次尝试匹配每个名称。我知道有更好的方法可以做到这一点,但这只是一个简单的例子来说明这一点。
答案似乎是否定的,没有真正的选择。在python中对正则表达式进行参数化的最佳方法是如上所述或使用诸如
str.format()
.
我试着写一个普通的问题,而不是
'修复ma codez,kthxbye'
. 对于那些仍然感兴趣的人,我在这里列举了一个更接近我需要的例子:
for diskfilename in os.listdir(''):
filenames = ['bob.txt', 'fred.txt', 'paul.txt']
for filename in filenames:
name, ext = filename.split('.')
regexp = "%s.*\.%s" % (name, ext)
m = re.search(regexp, diskfilename)
if m:
print diskfilename, regexp, re.search(regexp, diskfilename)
# ...
我正试图根据文件的文件名来确定文件的类型。
_.
. 在我的真实代码中,
filenames
数组是一个dict,包含一个在找到匹配项后要调用的函数。
我考虑过的其他方法:
数组中有一个正则表达式。
我已经有了一个没有任何正则表达式魔力的文件名数组,所以我不愿意这样做。我在我的代码中的其他地方做了这个,它是一个混乱的地方(尽管在那里是必要的)。
仅在文件名开头匹配。
这会有效,但会破坏文件的.bak副本等。在某个时候,我可能希望从文件名中提取日期,因此无论如何都需要使用正则表达式。
感谢您的回答,建议使用正则表达式的替代方法来获得相同的最终结果。我对现在和将来的正则表达式参数化更感兴趣。我从来没有遇到过
不匹配
从长远来看,这一切都是有用的。