python 处理微信对账单数据的实例代码


Posted in Python onJuly 19, 2019

下面一段代码给大家介绍python 处理微信对账单数据,具体代码如下所示:

#下载对账单并存储到数据库
@app.route("/bill/<string:date>",methods=["GET","POST"])
def download_bill(date):
 pay = MyWeiXinPay()#自己的支付类
 bill= pay.download_mybill(date)#下载原始对账单,下载下来为字符串
 billArray=bill.split("\r\n") #分割账单,一行为一组数据,分割后第一行为数据标题,倒数第三行为统计标题,倒数第二行为统计金额,最后一行为多余的空行
 titleArray=billArray[0].split(',')#第一行为标题
 title_total=billArray[len(billArray)-2] #统计标题
 data_total=billArray[len(billArray)-1]#统计金额
 del billArray[0] #去掉标题
 del billArray[len(billArray)-3] #去掉总标题
 del billArray[len(billArray)-2] #去掉总额
 del billArray[len(billArray)-1] #去掉空行,剩下的为账单详情数据
 mybill=[] #订单详细信息
 #循环账单详情数据
 for i in billArray:
 #每一条订单详细信息(去掉分隔出来的空数据)
 _detail=i.split('`')[:-1]
 del _detail[0]#去掉前边的空数据
 _detail_temp=[]
 for d in _detail:
  #每一个数据(去掉最后的逗号)
  _detail_val=d[:-1]
  _detail_temp.append(_detail_val)
  #TODO业务处理 
  # print(d[:-1])
 #TODO业务处理 
 mybill.append(_detail_temp)
 # print("---------------------------------------------")
 #返回值TODO
 return json.dumps(mybill)

ps:Python通过微信对账接口获取账单明细

由于工作需要,实现了用Python获取微信对账明细,最终生成CSV文件。

代码如下:

# -*- coding: utf-8 -*-
import urllib2
import hashlib
import datetime
'''登录微信公众号后台,可以查询到APPID和MCH_ID,并填写生成的KEY'''
APPID = ""
MCH_ID = ""
KEY = ""
#当天获取昨天一整天的微信支付数据
yesterday = datetime.date.today() + datetime.timedelta(-1)
TimeList = [
yesterday.strftime("%Y%m%d")
]
f = file("./test.csv", "w")
#创建CSV文件表头
f.write("交易时间,公众账号ID,商户号,子商户号,设备号,微信订单号,商户订单号,用户标识,交易类型,交易状态,付款银行,货币种类,总金额,代金券或立减优惠金额,微信退款单号,商户退款单号,退款金额,代金券或立减优惠退款,退款类型,退款状态,商品名称,商户数据包,手续费,费率\n".decode("utf-8").encode("gb2312"))
f.close()
cookies = urllib2.HTTPCookieProcessor()
opener = urllib2.build_opener(cookies)
#循环取时间列表里面的时间,并获取相对应的微信支付的记录
for date in TimeList:
 temp = "appid=%s&bill_date=%s&bill_type=ALL&mch_id=%s&nonce_str=21df7dc9cd8616b56919f20d9f679233&key=%s"
 temp = temp % (APPID, date, MCH_ID, KEY)
 MD5 = hashlib.md5()
 MD5.update(temp)
 data = '''
  %s
  %s
  ALL
  %s
  21df7dc9cd8616b56919f20d9f679233
  %s
 '''
 data = data % (APPID, date, MCH_ID, MD5.hexdigest().upper())
 request = urllib2.Request(
   url = r'https://api.mch.weixin.qq.com/pay/downloadbill',
   headers = {'Content-Type' : 'text/xml'},
   data = data)
 data = opener.open(request).read()
 print data
 #将获取的数据分行,放入列表中
 lines = data.split("\n")
 f = file("./test.csv", "a")
 #将获取的数据按行写入CSV文件
 for i in range(len(lines)):
  if i>0 and i
   f.write(lines[i].replace("`",""))
  i += 1
 f.close()

总结

以上所述是小编给大家介绍的python 处理微信对账单数据的实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Python 相关文章推荐
手动实现把python项目发布为exe可执行程序过程分享
Oct 23 Python
在Django框架中编写Context处理器的方法
Jul 20 Python
python3 与python2 异常处理的区别与联系
Jun 19 Python
python针对excel的操作技巧
Mar 13 Python
Python针对给定列表中元素进行翻转操作的方法分析
Apr 27 Python
python跳过第一行快速读取文件内容的实例
Jul 12 Python
python的中异常处理机制
Aug 30 Python
对Python3 goto 语句的使用方法详解
Feb 16 Python
浅谈Python大神都是这样处理XML文件的
May 31 Python
python深copy和浅copy区别对比解析
Dec 26 Python
Python Selenium操作Cookie的实例方法
Feb 28 Python
python数据处理之Pandas类型转换
Apr 28 Python
Python利用神经网络解决非线性回归问题实例详解
Jul 19 #Python
python障碍式期权定价公式
Jul 19 #Python
python+numpy实现的基本矩阵操作示例
Jul 19 #Python
由面试题加深对Django的认识理解
Jul 19 #Python
基于Python函数和变量名解析
Jul 19 #Python
python关于矩阵重复赋值覆盖问题的解决方法
Jul 19 #Python
对Python生成器、装饰器、递归的使用详解
Jul 19 #Python
You might like
php实现首页链接查询 友情链接检查的代码
2010/01/05 PHP
php常用的安全过滤函数集锦
2014/10/09 PHP
PHPUnit安装及使用示例
2014/10/29 PHP
php微信开发之关键词回复功能
2018/06/13 PHP
JTrackBar水平拖动效果
2007/07/15 Javascript
在模板页面的js使用办法
2010/04/01 Javascript
JS分页控件 可用于无刷新分页
2013/07/23 Javascript
js如何实现点击标签文字,文字在文本框出现
2015/08/05 Javascript
微信企业号开发之微信考勤百度地图定位
2015/09/11 Javascript
Highcharts使用简例及异步动态读取数据
2015/12/30 Javascript
Bootstrap基本插件学习笔记之标签切换(17)
2016/12/08 Javascript
jquery仿微信聊天界面
2017/05/06 jQuery
javascript实现非常简单的小数取整功能示例
2017/06/13 Javascript
详解使用Node.js 将txt文件转为Excel文件
2017/07/05 Javascript
Django+Vue.js搭建前后端分离项目的示例
2017/08/07 Javascript
shiro授权的实现原理
2017/09/21 Javascript
详解webpack编译多页面vue项目的配置问题
2017/12/11 Javascript
详解微信小程序文件下载--视频和图片
2019/04/24 Javascript
小程序外卖订单界面的示例代码
2019/12/30 Javascript
JS实现单张或多张图片持续无缝滚动的示例代码
2020/05/10 Javascript
vue项目使用$router.go(-1)返回时刷新原来的界面操作
2020/07/26 Javascript
Python 实现简单的电话本功能
2015/08/09 Python
利用python实现xml与数据库读取转换的方法
2017/06/17 Python
python中利用await关键字如何等待Future对象完成详解
2017/09/07 Python
Python图像处理实现两幅图像合成一幅图像的方法【测试可用】
2019/01/04 Python
PyTorch预训练的实现
2019/09/18 Python
Python+Selenium实现自动化的环境搭建的步骤(图文)
2020/09/01 Python
css3 position fixed固定居中问题解决方案
2014/08/19 HTML / CSS
css3 图片圆形显示 如何CSS将正方形图片显示为圆形图片布局
2014/10/10 HTML / CSS
庆八一活动方案
2014/01/25 职场文书
全国优秀辅导员事迹材料
2014/05/14 职场文书
交通事故和解协议书
2014/09/25 职场文书
立案决定书范文
2015/06/24 职场文书
python 远程执行命令的详细代码
2022/02/15 Python
Mysql表数据比较大情况下修改添加字段的方法实例
2022/06/28 MySQL
使用CSS实现音波加载效果
2023/05/07 HTML / CSS