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使用django获取用户IP地址的方法
May 11 Python
Python实现求笛卡尔乘积的方法
Sep 16 Python
python的numpy模块安装不成功简单解决方法总结
Dec 23 Python
解决python3中解压zip文件是文件名乱码的问题
Mar 22 Python
python 日志增量抓取实现方法
Apr 28 Python
Python实现二维曲线拟合的方法
Dec 29 Python
python使用turtle绘制国际象棋棋盘
May 23 Python
Pycharm保存不能自动同步到远程服务器的解决方法
Jun 27 Python
Python面向对象程序设计之静态方法、类方法、属性方法原理与用法分析
Mar 23 Python
解决jupyter notebook import error但是命令提示符import正常的问题
Apr 15 Python
如何使用PyCharm将代码上传到GitHub上(图文详解)
Apr 27 Python
python神经网络ResNet50模型
May 06 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
了解Joomla 这款来自国外的php网站管理系统
2010/03/11 PHP
对text数据类型不支持代码页转换 从: 1252 到: 936
2011/04/23 PHP
编写php应用程序实现摘要式身份验证的方法详解
2013/06/08 PHP
PHP中使用GD库创建圆形饼图的例子
2014/11/19 PHP
PHP实现登录搜狐广告获取广告联盟数据的方法【附demo源码】
2016/10/14 PHP
PHP面相对象中的重载与重写
2017/02/13 PHP
实现php删除链表中重复的结点
2018/09/27 PHP
js 控制页面跳转的5种方法
2013/09/09 Javascript
jquery动态调整div大小使其宽度始终为浏览器宽度
2014/06/06 Javascript
Linux下使用jq友好的打印JSON技巧分享
2014/11/18 Javascript
轻松使用jQuery双向select控件Bootstrap Dual Listbox
2015/12/13 Javascript
jquery制做精致的倒计时特效
2016/06/13 Javascript
wap手机端解决返回上一页的js实例
2016/12/08 Javascript
详解如何实现一个简单的Node.js脚手架
2017/12/04 Javascript
JavaScript判断日期时间差的实例代码
2018/03/01 Javascript
js获取html页面代码中图片地址的实现代码
2018/03/05 Javascript
layui加载数据显示loading加载完成loading消失的实例代码
2019/09/23 Javascript
jsonp格式前端发送和后台接受写法的代码详解
2019/11/07 Javascript
[02:38]2018年度DOTA2最佳劣单位选手-完美盛典
2018/12/17 DOTA
Python算术运算符实例详解
2017/05/31 Python
python numpy实现文件存取的示例代码
2019/05/26 Python
CSS3 3D位移translate效果实例介绍
2016/05/03 HTML / CSS
世界上第一个水枕头:Mediflow
2018/12/06 全球购物
Book Depository澳大利亚:世界领先的专业在线书店之一
2018/12/27 全球购物
医科大学生毕业的自我评价分享
2013/11/12 职场文书
开业庆典答谢词
2014/01/18 职场文书
高三自我评价
2014/02/01 职场文书
2014年秋季开学典礼致辞
2014/08/02 职场文书
党的群众路线对照检查材料(个人)
2014/09/24 职场文书
单位作风建设自查报告
2014/10/23 职场文书
党建工作整改措施
2014/10/28 职场文书
2015年民主生活会发言材料
2014/12/15 职场文书
2015年治庸问责工作总结
2015/07/27 职场文书
读《推着妈妈去旅行》有感1500字
2019/10/15 职场文书
提取视频中的音频 Python只需要三行代码!
2021/05/10 Python
python 如何将两个实数矩阵合并为一个复数矩阵
2021/05/19 Python