为了账号安全,请及时绑定邮箱和手机立即绑定

str.replace 除非字符串后跟某些文本

str.replace 除非字符串后跟某些文本

撒科打诨 2024-01-04 10:34:50
先前问题的修改:如何将所有“,”(即逗号然后空格)替换为“_”,除非“,”(逗号然后空格)后跟单词“LLC”或“Inc”(然后什么都不做)?我想改变:“德克萨斯能源互助有限责任公司、鲍比·吉利姆、史蒂夫·佩雷拉和安迪·斯蒂特”“葡萄有限责任公司、安德里亚·格雷、杰克·史密斯”“史蒂芬·温特斯,苹果,梨公司,莎拉·史密斯”对此:“德克萨斯能源互助有限责任公司_BOBBY GILLIAM_STEVE PEREIRA_ANDY STITT”“葡萄有限责任公司_安德里亚·格雷_杰克·史密斯”“史蒂芬·温特斯_苹果_梨公司_莎拉·史密斯”我认为它会从下面代码的一些变化开始,但我无法弄清楚例外条件。df['Column_Name'] = df['Column_Name'].str.replace(', ','_') 干杯!
查看完整描述

3 回答

?
四季花海

TA贡献1811条经验 获得超5个赞

您可以将正则表达式替换为负lookahead:

#no idea why Inc|LLC or LLC|Inc will skip the first

df['Column_Name'].str.replace(', (?!=|Inc|LLC)', '_')

输出:


0    TEXAS ENERGY MUTUAL, LLC_BOBBY GILLIAM_STEVE P...

1                    Grape, LLC_Andrea Gray_Jack Smith

2          Stephen Winters_Apple_pear, Inc_Sarah Smith

Name: ColumnName, dtype: object


查看完整回答
反对 回复 2024-01-04
?
炎炎设计

TA贡献1808条经验 获得超4个赞

使用 python 正则表达式模块re for 与模式, (?!Inc|LLC)查找所有出现的 , 不带以下IncLLC


import re


strings = ["Banana, orange", "Grape, LLC", "Apple, pear, Inc"]


[re.sub(", (?!Inc|LLC)",'_',string) for string in strings]

#['Banana_orange', 'Grape, LLC', 'Apple_pear, Inc']




查看完整回答
反对 回复 2024-01-04
?
LEATH

TA贡献1936条经验 获得超6个赞

简单的方法:


def replace(str):

   x = str.split(', ')

   buf = x[0]

   for i in range(1, len(x)): 

      if x[i].startswith('LLC'):

         buf += ', ' + x[i]

      elif x[i].startswith('Inc'):

         buf += ', ' + x[i]

      else:

         buf += '_' + x[i]

   return buf

然后尝试replace('a, b, LLC, d')


查看完整回答
反对 回复 2024-01-04
  • 3 回答
  • 0 关注
  • 123 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信