我对正则表达式和 Python 有点陌生,并且处于以下情况。我想采用一个方程式字符串,例如“A + B + C + 4D”,并将数字 1 放在前面没有数字的所有变量前面。所以类似:
>>> foo_eqn = "A + B + C + 4D"
>>> bar_eqn = fill_in_ones(foo_eqn)
>>> bar_eqn
"1A + 1B + 1C + 4D"
经过一番研究和询问,我想出了
def fill_in_ones(in_eqn):
out_eqn = re.sub(r"(\b[A-Z]\b)", "1"+ r"\1", in_eqn, re.I)
return(out_eqn)
但是,看起来这只适用于前两个变量:
>>> fill_in_ones("A + B")
1A + 1B
>>> fill_in_ones("A + B + E")
1A + 1B + E
>>> fill_in_ones("2A + B + C + D")
2A + 1B + 1C + D
我遗漏了什么明显的东西吗?谢谢!
最佳答案
看起来re.I
(忽略大小写标志)是罪魁祸首:
>>> def fill_in_ones(in_eqn):
... out_eqn = re.sub(r"(\b[A-Z]\b)", "1"+ r"\1", in_eqn)
... return(out_eqn)
...
>>>
>>> fill_in_ones("A + 3B + C + 2D + E")
'1A + 3B + 1C + 2D + 1E'
这是因为 re.sub 的下一个位置参数是count
,而不是flags
。您需要:
def fill_in_ones(in_eqn):
out_eqn = re.sub(r"(\b[A-Z]\b)", "1"+ r"\1", in_eqn, flags=re.I)
return(out_eqn)
不幸的是,re.I
标志恰好是 2
:
>>> import re
>>> re.I
2
关于python - Python 方程替换中的正则表达式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38000252/