如何将\s+
替换为单个spance,将所有;
替换为,
,将所有a.m
替换为AM
,将所有x
替换为y
{1}}
我是命名组替换的新手,如何使用单个RegEx和单个sub()调用将替换字符集替换为替换字符集。
如果我可以将所有替换字符串保存在dict中,并且只有一个RegEx字符串可以是智能方式。
Eg: M-Th 5:30 am-10 pm; F 5:30 a.m-10:30 p.m, Sa 10:30-10:30, Su 10:30-10 x y z x
Output: M-Th 5:30 AM-10 PM, F 5:30 AM - 10:30 PM, Sa 10:30 - 10:30, Su 10:30-10 y y z y
答案 0 :(得分:2)
试试这个,
mydict = {"\s+":" ", ";":",", "a.m":"AM","x":"y"}
mystr = "M-Th 5:30 am-10 pm; F 5:30 a.m-10:30 p.m, Sa 10:30-10:30, Su 10:30-10 x y z x"
for k, v in mydict.iteritems():
mystr = mystr.replace(k, v)
print mystr
<强>输出强>
M-Th 5:30 am-10 pm, F 5:30 AM-10:30 p.m, Sa 10:30-10:30, Su 10:30-10 y y z y
答案 1 :(得分:1)
考虑: -
import re
def sub(matchobj):
if matchobj.group(0) == ';':
return ':'
elif matchobj.group(0) == 'a.m.':
return 'AM'
elif re.match('\\s+$', matchobj.group(0)):
return ' '
print re.sub(';|\\s+|a.m.', sub, '10; a.m. ;')
示例运行: -
C:\>python st.py
10:AM
或者或许(从Ammar借来我喜欢简洁的解决方案:): -
import re
mydict = {"\s+":" ", ";":",", "a.m":"AM","x":"y"}
def sub(matchobj):
for k, v in mydict.iteritems():
if re.match('%s$' % k, matchobj.group(0)):
return v
print re.sub('|'.join(mydict.keys()), sub, 'M-Th 5:30 am-10 pm; F 5:30 a.m-10:30 p.m, Sa 10:30-10:30, Su 10:30-10 x y z x')
哪个也有效: -
C:\>python st.py
M-Th 5:30 am-10 pm, F 5:30 AM-10:30 p.m, Sa 10:30-10:30, Su 10:30-10 y y