First of all
通过观察,我发现我的微信消费类型大约有3种:
1.通过扫描商家二维码支付
2.直接进行商户消费
3.发红包给舍友让他们帮我带饭
接下来,我要统计具体的消费明细
一、准备工作
首先,需要在微信上导出消费账单。然后把没用的信息删掉。像这样
下面安装库
pip install xlrd
pip install xlwt
第一个库是读取xls文件,第二个是写入xls文件(第一个库支持xlsx,第二个不支持)
二、开始写代码
1.引入库
代码如下(示例):
import xlrd import xlwt import os import shutil 1234
后面的两个库的作用下面再说
2.打开表格
代码如下(示例):
data = xlrd.open_workbook(r'C:\Users\xvjiu\Desktop\python\统计\微信支付账单.xls') #打开文件 table = data.sheet_by_index(0) #初始化表格 row = table.nrows #统计行数 col = table.ncols #统计列数 1234
3.读入数据
代码如下(示例):
for i in range(1,row): type_=table.cell_value(i,0) #对应A列 交易类型 name_=table.cell_value(i,1) #对应B列 交易对方 ojbk_=table.cell_value(i,2) #对应C列 商品 shzh_=table.cell_value(i,3) #对应D列 收支 qian_=table.cell_value(i,4) #对应E列 金额 123456
4.整理数据
我用列表储存交易对方(b列) 用字典来统计一个商品所消费的总金额
if type_=="扫二维码付款" : if name_ in li0: d2[name_]=d2[name_]+int(qian_) else: d2[name_]=int(qian_) li0.append(name_) if type_=="商户消费" : name_=name_+str(ojbk_) if name_ in li1: d2[name_]=d2[name_]+int(qian_) else: d2[name_]=int(qian_) li1.append(name_) if type_=="微信红包(单发)" : name_=name_+str(ojbk_) if name_ in li3: d2[name_]=d2[name_]+int(qian_) else: d2[name_]=int(qian_) li3.append(name_) if type_=="微信红包(群红包)" :#li4 d2 name_=name_+str(ojbk_) if name_ in li4: d2[name_]=d2[name_]+int(qian_) else: d2[name_]=int(qian_) li4.append(name_) 12345678910111213141516171819202122232425262728293031323334
5.写入数据
代码如下(示例):
------------------------------------------------------------初始化写入--------------------- file_name = "zyz" + ".xls" workbook = xlwt.Workbook(encoding = 'utf-8') worksheet = workbook.add_sheet('sheet1') #------------------------------------------------------------写入文件----------------------- li=*** #替换列表 d=*** #替换字典 for i in range(len(li)): worksheet.write(i,1, label = d[li[i]]) worksheet.write(i,0, label = li[i]) #------------------------------------------------------------转移文件路径--------------------- workbook.save(file_name) aa = os.getcwd() file_path = os.path.join(aa, file_name) target_path = r'C:\Users\Desktop\python\******.xls' #替换文件名 shutil.move(file_path, target_path ) 1234567891011121314151617181920
由于xlwt这个库不支持自定义导出路径,所以需要我们用os和shutil来自定义导出路径
6.输出结果
最后
上面这些据说完全可以通过excel的函数来实现,不过正经人谁会去听计算思维
*声明:本文于网络整理,版权归原作者所有,如来源信息有误或侵犯权益,请联系我们删除或授权事
近期有很多朋友通过私信咨询有关Python学习问题。为便于交流,点击蓝色自己加入讨论解答资源基地