gpt4 book ai didi

python - 在匹配组中用下划线替换空格字符?

转载 作者:行者123 更新时间:2023-12-01 03:05:13 26 4
gpt4 key购买 nike

我有一个看起来像这样的字符串:

"(当 Campaign='Back to School' 且 VariableName='Total_FB_Spend' 时,则 VariableValue else 0 end) AS Back to School_Total_FB_Spend,(当 Campaign='Back to School' 且 VariableName='Total_FB_Imp' 时的情况)然后 VariableValue else 0 end) AS 返回 School_Total_FB_Imp"

我想使用 Python 正则表达式删除“end) AS”字符后列名称中的空格。结果应该是这样的

"(当 Campaign='返校'且 VariableName='Total_FB_Spend' 时则 VariableValue else 0 结束) AS Back_to_School_Total_FB_Spend,(当 Campaign='返校'且 VariableName='Total_FB_Imp' 时则 VariableValue否则 0 结束)AS Back_to_School_Total_FB_Imp"

我能够使用 Python 中的正则表达式来匹配我感兴趣的部分 [example here]但我想知道如何优雅地(例如,一个衬垫或以 Pythonic 方式)替换匹配组中的空格字符。

最佳答案

您需要一个带有 lambda 表达式的 re.sub 作为替换参数:

import re
s = "(case when Campaign='Back to School' and VariableName='Total_FB_Spend' then VariableValue else 0 end) AS Back to School_Total_FB_Spend,(case when Campaign='Back to School' and VariableName='Total_FB_Imp' then VariableValue else 0 end) AS Back to School_Total_FB_Imp"
pat = r'(end\) as )([^,]*)'
print(re.sub(pat, lambda m: "{}{}".format(m.group(1), m.group(2).replace(" ", "_")), s))

请参阅Python demo

请注意,我用更高效的 ([^,]*) 替换了您的 (.*?(,|$)),任何零个或多个字符其他比。现在,整个正则表达式匹配:

  • (end\) as ) - 第 1 组:end) as
  • ([^,]*) - 第 2 组:除 之外的任何零个或多个字符

然后,使用lambda m: "{}{}".format(m.group(1), m.group(2).replace("", "_")),第一个捕获组的内容原封不动地复制回结果,第二个捕获组的内容使用 .replace("", "_") 进行修改。当然,如果可能有空格,您可以对其运行另一个正则表达式,re.sub(r'\s+', '_', m.group(2))

关于python - 在匹配组中用下划线替换空格字符?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43506433/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com