我正在使用以下代码:
re.sub(inputpattern,outputpattern, currentline)
在上面的代码中,我正在读取csv中outputpattern的值,其值为:
\\1-\\2-\\3-\\4
我正在阅读如下:
outputpattern = row['PREFIX_1_WRT_FMT']
我也尝试过:
outputpattern = "'"+ row['PREFIX_1_WRT_FMT'] +"'"
问题在于它没有将其视为正确的格式,但如果我像下面那样对它进行硬编码就可以正常工作:
re.sub(inputpattern,'\\1-\\2-\\3-\\4', currentline)
答案 0 :(得分:1)
如果您将反斜杠作为文字字符串,则只需要转义反斜杠。
"\\1-\\2-\\3-\\4"
如果您从输入中读取它,则不必这样做。您需要将CSV中的模式更改为\ 1- \ 2- \ 3- \ 4
如果您不喜欢在使用文字字符串时转义每个字符,也可以使用原始字符串,方法是在字符串前加上字母r。
r"\1-\2-\3-\4"