python统计微信消费


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

后面的两个库的作用下面再说

2.打开表格

代码如下(示例):

data = xlrd.open_workbook(r'C:\Users\xvjiu\Desktop\python\统计\微信支付账单.xls') #打开文件
table = data.sheet_by_index(0)   #初始化表格
row = table.nrows    #统计行数
col = table.ncols    #统计列数

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列  金额

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_)

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 )

由于xlwt这个库不支持自定义导出路径,所以需要我们用os和shutil来自定义导出路径

6.输出结果

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述


最后

上面这些据说完全可以通过excel的函数来实现,不过正经人谁会去听计算思维

在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值