盘点一个Python自动化办公实战实现数据汇总填充(方法四)

点击上方“Python爬虫与数据挖掘”,进行关注

回复“书籍”即可获赠Python从入门到进阶共10本电子书

愿陛下托臣以讨贼兴复之效,不效,则治臣之罪,以告先帝之灵。

大家好,我是皮皮。

一、前言

前几天在Python最强王者交流群【哎呦喂  是豆子~】问了一个Python自动化办公的问题,一起来看看吧。

46eaa666a9b3f12e4d55a751f8d6f6e8.png

下图是他的原始数据和他想得到的目标数据,如下所示:

dfb7f91f893d1fac6792fb875a17da78.png

需要在标黄的两行里边进行相关操作。

二、实现过程

之前的文章中【莫生气】使用了openpyxl进行了实现,的确可行,但是那只是针对小批量数据表,单单几个漏洞的情况下,还算可以hold住的,但是在多个漏洞的情况下,比方说几十个这样,那挨个的去写,还是非常吃力里的。这一篇文章我们一起来看看【隔壁😼山楂】大佬给出的pandas实现,非常秀儿。

下面是他提供的代码:

# 筛选或条件
dfc1 = df.groupby(['系统名称', '漏洞名称', '是否提供误报证明']).agg({'ip': 'unique'}).rename(columns={'ip': '已提供误报证明ip'}).reset_index()
dfc2 = df.groupby(['系统名称', '漏洞名称', '是否提供无法整改证明']).agg({'ip': 'unique'}).rename(columns={'ip': '已提供无法整改证明ip'}).reset_index()
res = dfc1.merge(dfc2, how='outer', left_on=['系统名称', '漏洞名称', '是否提供误报证明'], right_on=['系统名称', '漏洞名称', '是否提供无法整改证明'])
res1 = res.loc[res['是否提供误报证明'].eq('是') & res['是否提供无法整改证明'].eq('是')].copy()
res1.set_index(['系统名称', '漏洞名称'], inplace=True)
# 筛选与条件
res2 = df[df['是否提供误报证明'].eq('否') & df['是否提供无法整改证明'].eq('否')].groupby(['系统名称', '漏洞名称']).agg({'ip': 'unique'}).rename(columns={'ip': '没有误报和无法整改证明的ip'})
# 结果合并
res = res1.join(res2, how='outer').fillna('')
# 将结果列表处理成字符串
ip_cols = res.columns[res.columns.str.contains('ip')]
res[ip_cols] = res[ip_cols].applymap(', '.join)
# 无ip的单元格用无填充
res[ip_cols] = res[ip_cols].where(res[ip_cols].ne(''), '无')
# 保存结果
res.to_excel('result.xlsx', index=False)

这个简单来说就是筛选三次,三次的结果进行合并,运行之后可以得到预期的效果图如下所示:

ba6fd49c112591f4006c233ee93fb2e1.png

顺利地解决了粉丝的问题。细心的小伙伴可能已经发现了,这里只是显示了2个漏洞的情况,那么针对多漏洞的情况,又该如何进行实现呢?下一篇文章,【隔壁😼山楂】继续给大家带来惊喜,敬请期待!

三、总结

大家好,我是皮皮。这篇文章主要盘点了一个Python自动化办公实战的问题,文中针对该问题,给出了具体的解析和代码实现,帮助粉丝顺利解决了问题。

最后感谢粉丝【哎呦喂  是豆子~】提问,感谢【莫生气】、【隔壁😼山楂】给出的思路和代码解析,感谢【鶏啊鶏。】、【Ineverleft】等人参与学习交流。

【提问补充】温馨提示,大家在群里提问的时候。可以注意下面几点:如果涉及到大文件数据,可以数据脱敏后,发点demo数据来(小文件的意思),然后贴点代码(可以复制的那种),记得发报错截图(截全)。代码不多的话,直接发代码文字即可,代码超过50行这样的话,发个.py文件就行。

b20ee16b373b5adfa67d73c0f24e1458.png

大家在学习过程中如果有遇到问题,欢迎随时联系我解决(我的微信:pdcfighting1),应粉丝要求,我创建了一些ChatGPT机器人交流群和高质量的Python付费学习交流群和付费接单群,欢迎大家加入我的Python学习交流群和接单群!

aa642f48f8ed9d8df6e427fdad2a4103.png

小伙伴们,快快用实践一下吧!如果在学习过程中,有遇到任何问题,欢迎加我好友,我拉你进Python学习交流群共同探讨学习。

ea810456797dcde6ddc07a4a395089d6.jpeg

------------------- End -------------------

往期精彩文章推荐:

41c3dd1930656d60b924d3f9c69c95c4.png

欢迎大家点赞,留言,转发,转载,感谢大家的相伴与支持

想加入Python学习群请在后台回复【入群

万水千山总是情,点个【在看】行不行

/今日留言主题/

随便说一两句吧~~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值