1

如何替换\s+为单个空格、全部;,、全部a.mAM、全部xy 我是命名组替换的新手,如何使用单个 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
4

2 回答 2

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
于 2012-12-14T10:00:51.547 回答
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
于 2012-12-14T10:00:35.133 回答