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 测试实现方法
Dec 24 Python
在Python的Django框架中创建语言文件
Jul 27 Python
Python编写电话薄实现增删改查功能
May 07 Python
python爬取足球直播吧五大联赛积分榜
Jun 13 Python
django rest framework 数据的查找、过滤、排序的示例
Jun 25 Python
Python2包含中文报错的解决方法
Jul 09 Python
python实现雪花飘落效果实例讲解
Jun 18 Python
Python如何使用字符打印照片
Jan 03 Python
520使用Python实现“我爱你”表白
May 20 Python
python list的index()和find()的实现
Nov 16 Python
Python自动化之批量处理工作簿和工作表
Jun 03 Python
深入理解python协程
Jun 15 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
SONY ICF-F10中波修复记
2021/03/02 无线电
PHP命名空间和自动加载类
2016/04/03 PHP
老生常谈PHP面向对象之注册表模式
2017/05/26 PHP
TP5框架实现上传多张图片的方法分析
2020/03/29 PHP
重定向实现代码
2006/11/20 Javascript
xtree.js 代码
2007/03/13 Javascript
js中的window.open返回object的错误的解决方法
2009/08/15 Javascript
jQuery的强大选择器小结
2009/12/27 Javascript
IE与Firefox在JavaScript上的7个不同句法分享
2011/10/30 Javascript
JQuery插件Style定制化方法的分析与比较
2012/05/03 Javascript
js的正则test,match,exec详细解析
2014/01/29 Javascript
js自定义鼠标右键的实现原理及源码
2014/06/23 Javascript
JavaScript动态加载样式表的方法
2015/03/21 Javascript
基于jQuery实现表格的查看修改删除
2016/08/01 Javascript
NodeJs安装npm包一直失败的解决方法
2017/04/28 NodeJs
Javascript实现base64的加密解密方法示例
2017/06/27 Javascript
通过js控制时间,一秒一秒自己动的实例
2017/10/25 Javascript
用React实现一个完整的TodoList的示例代码
2017/10/30 Javascript
vue2.0在没有dev-server.js下的本地数据配置方法
2018/02/23 Javascript
Node.js 使用AngularJS的方法示例
2018/05/11 Javascript
element-ui 中使用upload多文件上传只请求一次接口
2019/07/19 Javascript
原生JavaScript写出Tabs标签页的实例代码
2020/07/20 Javascript
[01:08:10]2014 DOTA2国际邀请赛中国区预选赛 SPD-GAMING VS LGD-CDEC
2014/05/22 DOTA
[03:57]DOTA2英雄梦之声_第03期_幻影刺客
2014/06/21 DOTA
python中kmeans聚类实现代码
2018/02/23 Python
浅谈Python 列表字典赋值的陷阱
2019/01/20 Python
python中setuptools的作用是什么
2020/06/19 Python
详解HTML5中垂直上下居中的解决方案
2017/12/20 HTML / CSS
HTML5新表单元素_动力节点Java学院整理
2017/07/12 HTML / CSS
配置H5的滚动条样式的示例代码
2018/03/09 HTML / CSS
为什么要使用servlet
2016/01/17 面试题
合同协议书格式
2014/04/18 职场文书
会计专业毕业生求职信
2014/07/04 职场文书
护理目标管理责任书
2014/07/25 职场文书
2014年学校食堂工作总结
2014/11/25 职场文书
法律意见书范文
2015/05/20 职场文书