hrt5f 2022-07-11 19:07 采纳率: 69.2%
浏览 19
已结题

Excel按条件查找和写入

我现在有这么一个Excel文件(01.xlsx),包含下列内容。

第一小组 发货单号
张三 XA98E
李四 XD930
王五 XA325
第二小组 (空)
老六 XAL938
董七 XE736

需求:找出发货单号为XA开头的人名,以及所属小组名称写在另外一个Excel文件(02.xlsx)。
02.xlsx文件包括另外的行。
期待结果,02.xlsx文件内容应如下,

小组信息 名称 发货单号
第一小组 张三 XA98E
第一小组 王五 XA325
第二小组 老六 XAL938

自己用openpyxl和pandas折腾了一周多时间,但没有实质性进展,头都大了。
烦请各位帮忙指导,在此感谢!

  • 写回答

1条回答 默认 最新

  • 快乐小土狗 2022-07-11 21:21
    关注

    img

    img

    
    #将第二列空去掉
    df[2] = df[2].fillna('None')
    #将第一列值拿出来,为了区分小组
    df[0] = df[1]
    #将新列第**小组的元素赋空
    df[0] = df[0].mask(~df[0].str.contains("第.*?小组"), None)
    #将新列空值以上面最近不为空的值填充
    df[0] = df[0].fillna(method='ffill')
    #将第一列值为第**小组的行删除
    df = df.drop(df[df[1].str.contains("第.*?小组")].index)
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

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

悬赏问题

  • ¥30 关于用python写支付宝扫码付异步通知收不到的问题
  • ¥50 vue组件中无法正确接收并处理axios请求
  • ¥15 隐藏系统界面pdf的打印、下载按钮
  • ¥15 MATLAB联合adams仿真卡死如何解决(代码模型无问题)
  • ¥15 基于pso参数优化的LightGBM分类模型
  • ¥15 安装Paddleocr时报错无法解决
  • ¥15 python中transformers可以正常下载,但是没有办法使用pipeline
  • ¥50 分布式追踪trace异常问题
  • ¥15 人在外地出差,速帮一点点
  • ¥15 如何使用canvas在图片上进行如下的标注,以下代码不起作用,如何修改