python汇总excel表_Python 处理分析 128 张 Excel 表格竟不到3秒?|附数据集

38dbb6fd5266d016ce1774b6b83edc0135fa3539.jpeg?token=8ec50a2c26043575f747ceea51c5d153&s=5D65A9444C930ED64B5F79810300E098

作者 | 周志鹏

责编 | 刘静

有不少旁友想要了解怎么用Python提升处理数据的效率,或者说怎么用Python自动处理多张Excel表格,于是乎便有了本文。这篇文章算是Python数据分析实战的第二个独立案例。

案例背景

在另一个平行世界,有一家专注于户外运动的巨头公司。既然是巨头,为了更加亲切,我们就叫他大头吧。大头的旗下有20个品牌,这些品牌涉及到128个类目(细分行业),涉及范围之广令人咋舌,可谓遍地开花。

平行世界的小Z就是这家巨无霸的数据分析师,今天刚来公司就接到了一个需求——下班前务必筛选出近一年销售额总额TOP5的品牌以及对应的销售额。

近一年?TOP5?

WOC,这么简单的需求也算需求?直接排个序不就好了。

还一天时间,不急不急,先来一杯咖啡,再看看新闻。

42a98226cffc1e17052d8e2e7985fe05738de93e.jpeg?token=fa288d5090b6db3caee4b96cdb80fabb&s=6BA6326208F071AD389490D90100C0E0

一眨眼的功夫,时间来到了17:30,小Z觉得今天的需求可以开动了,做完之后还能简单分析一下,应该能赶在18:00整点下班。

当他打开同事共享给他的表格文件,他才体会到,绝望,原来这么远,又这么近。

c3a9bde1a4ee9426723008374c99d7823007.gif

业务部门的同事总共发来了128张表,每一份表格对应着一个细分行业的数据,像什么各类户外服装、垂钓装备、救生装备应有尽有。

8b13632762d0f703621b573933ef593b2797c542.jpeg?token=1c3c0be365ec6722fce4013bce2c9941&s=C010CC32099DF0CA1E7500CF030010B2

每张表,以月的维度(2018年9月-2019年8月,近一年)记录着每个品牌的日期、访客、客单、转化、所属类目(细分行业)等数据:

3bf33a87e950352aaa0bbeed6e56f3f4b3118b8c.png?token=a96ea87e15a91e25dfbbb2011dc90288&s=3E8A722392D479EB12D5B5CB0000C0A0

注:不要问为啥表格数据存储这么奇葩,因为在平行世界,就是要任性,毕竟复杂的表格才能体现出Python的高效

小Z开始盘算,最终需求是要筛选出近一年销售额总和排名前5的品牌,这一摊子数据,对单独的一张表进行分类汇总,能够得到该细分行业各品牌的销售额,想要得到所有行业的销售额总和,得分类汇总128次,最后对128次结果再次合并。

“这个任务看上去很艰巨,不过,考验的主要是体力。”小Z一眼就“看穿”了事情的本质。同时脑海中蹦出了“红军不怕远征难”几个红彤彤的大字。接着,他带上耳机,打开了唐朝乐队的“国际歌”,在双重buff的加持下,开始了表格的远征。

abc361057ff7a1073050eb2418d93d361898.gif

果然是个处理数据的好手,小Z右手食指在鼠标上飞速跳动,以90秒一张表格的速度疯狂推进。按照这个速度,不考虑疲劳值对速度的拖累,大概3.2个小时就能够完成任务。

国际歌循环到第10遍,小Z有些气馁,第20遍,开始感到绝望。

ed22445748805abdd174c9ee6a2a746f6883.gif

就在行将放弃之际,他想起了Python的潘大师(Pandas),虽然最近刚学还不是很熟练,但事到临头,黑暗中的一缕微光,那就是唯一的希望,小Z决定用Pandas来尝试解决问题。

他明白,用Python解决批量问题的核心,在于梳理并解决单个问题,然后批量循环。

单个表格处理

首先,导入模块,打开单个表格:

0bd162d9f2d3572c3c400ca8c7066b2162d0c33b.png?token=9bff23e2b24a80eeef1339845561813b&s=D59AEC335DDB41CA5EE1A0DB000050B3

接着,是要汇总不同品牌在这个细分行业下的销售额,我们要汇总的是各品牌近一年(2018年9月-2019年8月)的销售额,先看看日期是否正确:

0b55b319ebc4b745da0c8f4980e916118b8215eb.png?token=c16994bbe177bd821665bbf08e8d0738

正要汇总销售额,小Z发现没有销售额的字段,但销售额是可以通过访客数*转化率*客单价三者的乘积来计算的:

7a899e510fb30f24432454789980d945ad4b032d.png?token=ef929eeb39b3695cbf37e983a51edd3f&s=5C98EC1A97D04DC214D1D1D6000080B3

按品牌来汇总销售额,得到近一年各品牌销售额合计:

37d12f2eb9389b500c4730a0d120eddbe6116ea7.png?token=fb180fe887cc340c6636b803ce2547b2&s=509AEC3213704C20085CA1DA0000C0B3

这里有个细节,最终小Z要汇总的是所有细分行业的销售额,对于单独行业的销售额,应该加一个区分的标签以防覆盖,而打开时候的文件名,具有天然的区分和防覆盖优势,但要注意去掉文件的后缀。

b7fd5266d0160924b6e8f6188c123dfce7cd34fa.png?token=e06f15d7bac03c09eb73febc5810b263&s=5098EC339FC0404304D4E9DA000090B2

OK,单个表格处理完成,我们把这一系列操作推而广之即可。

批量循环执行

小Z用os.listdir方法来遍历文件名,批量循环访问并处理文件,同时引入time计时,打算看一看,面对128张表,Python完成这些操作到底能够比手动快多少:

faedab64034f78f045584e4d22240253b2191cdc.png?token=92211e0910894d8fb5e138fece560ffe&s=6C8A7D3219CA454D5E5DADD2000010B2

WOC,整个过程一气呵成,不到3秒,平均一张表格0.02秒!真香!

为了确保数据正常,来预览一下:

342ac65c103853432e3f958bcd06b878cb808847.png?token=c05705063743be3b2cfb874fd6dcbaf6&s=EF90EC0B0B2245205A5DA1DA0000D0B3

这一串看起来很奇怪的销售额,是pandas自作主张把实际销售额变成了科学记数法形式来展示,要还原数值,需要更改一下原始的设置:

0ff41bd5ad6eddc46909b7a458cebefb53663399.png?token=7bb5b3e0e61334fab446401b9cf64446&s=6292EC2B111F55CE08F584DA0000C0B2

OK,无论是习惯还是法理,都得到了我们希望的结果——近一年销售TOP5品牌及其对应的销售额。从数据结果来看,大头公司下的20个品牌全面开花,以品牌5为先锋,一年销售高达12.26亿,排名最后的品牌体量也达到了9.79亿元,平均单品牌销售10.85亿元。

总结

本文以一个简单又复杂的场景切入,简单是需求本身非常简单,而复杂则是基础数据涉及到的表格多而杂。代码和逻辑本身浅显易懂,主要为了抛出一块砖,敲开批量处理表格的思维藩篱,以引出同志们实践中,在合适场景下用Python来化繁为简的玉。案例中表格共128张,大家可以自己尝试和探索更有趣的分析。

数据资料GitHub下载地址:https://github.com/seizeeveryday/DA-cases/tree/master/Python%2Bexcel

作者:周志鹏,2年数据分析,深切感受到数据分析的有趣和学习过程中缺少案例的无奈,遂新开公众号「数据不吹牛」,定期更新数据分析相关技巧和有趣案例(含实战数据集),欢迎大家关注交流。

声明:本文为作者投稿,版权归作者个人所有。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值