Lin_Cainiaoyige 2022-02-21 15:30 采纳率: 71.4%
浏览 35
已结题

Python Dataframe 根据其中一列判断 来增减字符

我有一个Dataframe
df = pd.DataFrame({'Category':['A','C','D','C,D','C,D','A,B,C','A,D','C','C','C','C','C','A,D','A,B,C','A,B,C','A,B,C','D','D','D','D','D'],
'Logic':['Add C','Add D','Add C','','','Del C','Add C','','','Del C','','Add E','Add C','','Upd B To F','','','','','Upd D To F','Add B']})

img

我想根据‘Logic’这列的提示 对 Category这列进行更改 达到以下结果

img


请各位帮助 谢谢!

  • 写回答

1条回答 默认 最新

  • heianduck 2022-02-21 16:05
    关注
    import pandas as pd
    df = pd.DataFrame({'Category':['A','C','D','C,D','C,D','A,B,C','A,D','C','C','C','C','C','A,D','A,B,C','A,B,C','A,B,C','D','D','D','D','D'],
    'Logic':['Add C','Add D','Add C','','','Del C','Add C','','','Del C','','Add E','Add C','','Upd B To F','','','','','Upd D To F','Add B']})
    
    def judge(rawStr, condition):
        if "Add" in condition:
            addValue = ",".join(i for i in condition.split(' ')[1:])
            newStr = rawStr +','+addValue
            return newStr
        elif "Del" in condition:
            delValue = condition.split(' ')[-1]
            if "," in rawStr:
                rawList = rawStr.split(',')
                rawList.remove(delValue)
                newStr = ",".join(i for i in rawList)
                return newStr
            else: 
                return ""
        elif "Upd" in condition:
            rawV = condition.split(' ')[1]
            newV = condition.split(' ')[3]
            newStr = rawStr.replace(rawV,newV)
            return newStr
        else:
            return rawStr
    df['Category_result'] = df.apply(lambda x: judge(x['Category'],x['Logic']),axis=1)
    

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 3月2日
  • 已采纳回答 2月22日
  • 创建了问题 2月21日

悬赏问题

  • ¥15 Selenium+docker Chrome不能运行
  • ¥15 能给我一些人生建议吗
  • ¥15 mac电脑,安装charles后无法正常抓包
  • ¥18 visio打开文件一直显示文件未找到
  • ¥15 请教一下,openwrt如何让同一usb储存设备拔插后设备符号不变?
  • ¥50 使用quartz框架进行分布式任务定时调度,启动了两个实例,但是只有一个实例参与调度,另外一个实例没有参与调度,不知道是为什么?请各位帮助看一下原因!!
  • ¥50 怎么获取Ace Editor中的python代码后怎么调用Skulpt执行代码
  • ¥30 fpga基于dds生成幅值相位频率和波形可调的容易信号发生器。
  • ¥15 R语言shiny包和ncdf4包报错
  • ¥15 origin绘制有显著差异的柱状图和聚类热图