我对正则表达式的最后一部分有困难,这是我尝试将字符串拆分为
TODAY()
import re
s1 = 'A+" hello"+B'
s2 = 'A+(100-20)'
s3 = 'A-B+TODAY()-100'
print (re.split('([A-Z]+|["].?["]|[\=\+\-\%\*\^]|\bTODAY\(\)\b)', s1))
#expected ['', 'A', '', '+', '" hello"', '+', '', 'B', '']
#actual ['', 'A', '', '+', '" hello"', '+', '', 'B', '']
print (re.split('([A-Z]+|["].?["]|[\=\+\-\%\*\^]|\bTODAY\(\)\b)', s2))
#expected ['', 'A', '', '+', '(', '100', '-', '20', ')']
#actual ['', 'A', '', '+', '(100', '-', '20)']
print (re.split('([A-Z]+|["].?["]|[\=\+\-\%\*\^]|\bTODAY\(\)\b)', s3))
#expected ['', 'A', '', '-', '', 'B', '', '+', '', 'TODAY', '()', '-', '100']
#actual ['', 'A', '', '-', '', 'B', '', '+', '', 'TODAY()', '-', '100']
编辑:更正,意思是说任何长度的字符都用双引号括起来
今天匹配()的模式应该是第一种选择
相关问题 更多 >
编程相关推荐