SunHaYu 2022-01-25 18:37 采纳率: 100%
浏览 25
已结题

用python进行分组,将第一个词想同的变量分在同一组,并求和

问题遇到的现象和发生背景

我需要用python进行分组,分组是基于变量名称的第一个单词
比如下图表格中的情况:

img

我要把开头都是Apple的分为一组,开头都是baby的分为另一组,同时表格中的变量要保持不变,还要将同组中的B列值求和。我想要的效果大概如下:

img

我是尝试了用groupby和split函数。split函数先把首词分开,首词创建一个新列,然后基于新列用group.sum()求和,结果就不是我上面想要的效果了。代码如下:

Shipmanager_full_number['Shipmanager 2'] = Shipmanager_full_number['Shipmanager']
Shipmanager_full_number['Shipmanager 2'] = Shipmanager_full_number['Shipmanager 2'].str.split(' ', n=1, expand=True)
Shipmanager_full_number

Shipmanager_alias_number = Shipmanager_full_number.groupby('Shipmanager 2', as_index=False).sum()

想请教一下该怎么实现想要的效果呢?

问题相关代码,请勿粘贴截图
运行结果及报错内容
我的解答思路和尝试过的方法
我想要达到的结果
  • 写回答

2条回答 默认 最新

  • CSDN专家-HGJ 2022-01-25 22:59
    关注

    试试这样:

    import pandas as pd 
    
    df=pd.read_csv('datas/t1.csv')
    df['new']=df['A'].str.split(
    ' ',expand=True)[0]
    a = df.groupby('new')['B'].sum()
    df.index=df['new']
    df['B列合计']=a
    print(df)
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 2月15日
  • 已采纳回答 2月7日
  • 创建了问题 1月25日

悬赏问题

  • ¥170 如图所示配置eNSP
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效
  • ¥15 悬赏!微信开发者工具报错,求帮改
  • ¥20 wireshark抓不到vlan
  • ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真
  • ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持
  • ¥15 stata安慰剂检验作图但是真实值不出现在图上
  • ¥15 c程序不知道为什么得不到结果
  • ¥15 键盘指令混乱情况下的启动盘系统重装