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 threading多线程编程实例
Sep 18 Python
跟老齐学Python之print详解
Sep 28 Python
初学Python函数的笔记整理
Apr 07 Python
Pycharm 实现下一个文件引用另外一个文件的方法
Jan 17 Python
计算机二级python学习教程(2) python语言基本语法元素
May 16 Python
python 判断linux进程,并杀死进程的实现方法
Jul 01 Python
详解使用django-mama-cas快速搭建CAS服务的实现
Oct 30 Python
python飞机大战 pygame游戏创建快速入门详解
Dec 17 Python
keras模型可视化,层可视化及kernel可视化实例
Jan 24 Python
Python爬虫之Selenium中frame/iframe表单嵌套页面
Dec 04 Python
python实现简单的名片管理系统
Apr 26 Python
对Keras自带Loss Function的深入研究
May 25 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
是否存在第一台收音机的说法
2021/03/01 无线电
PHP插入排序实现代码
2013/04/04 PHP
php使用file函数、fseek函数读取大文件效率对比分析
2016/11/04 PHP
PHP实现的策略模式简单示例
2017/08/25 PHP
JQuery AJAX 中文乱码问题解决
2013/06/05 Javascript
Jquery操作radio的简单实例
2014/01/06 Javascript
div失去焦点事件实现思路
2014/04/22 Javascript
对之前写的jquery分页做下升级
2014/06/19 Javascript
js+jquery实现图片裁剪功能
2015/01/02 Javascript
JavaScript中几种排序算法的简单实现
2015/07/29 Javascript
JavaScript中的数据类型转换方法小结
2015/10/26 Javascript
JavaScript知识点总结(十六)之Javascript闭包(Closure)代码详解
2016/05/31 Javascript
js基础之DOM中元素对象的属性方法详解
2016/10/28 Javascript
d3.js中冷门却实用的内置函数总结
2017/02/04 Javascript
微信、QQ、微博、Safari中使用js唤起App
2018/01/24 Javascript
详解vue后台系统登录态管理
2019/04/02 Javascript
使用IronPython把Python脚本集成到.NET程序中的教程
2015/03/31 Python
Python利用splinter实现浏览器自动化操作方法
2018/05/11 Python
Python3之简单搭建自带服务器的实例讲解
2018/06/04 Python
python MNIST手写识别数据调用API的方法
2018/08/08 Python
Python3中内置类型bytes和str用法及byte和string之间各种编码转换 问题
2018/09/27 Python
python实现输出一个序列的所有子序列示例
2019/11/18 Python
如何解决pycharm调试报错的问题
2020/08/06 Python
使用CSS3的box-sizing属性解决div宽高被内边距撑开的问题
2016/06/28 HTML / CSS
上学迟到的检讨书
2014/01/11 职场文书
节电标语大全
2014/06/23 职场文书
学校领导班子对照检查材料
2014/09/24 职场文书
党的群众路线教育实践活动整改落实情况报告
2014/10/28 职场文书
幼儿园大班见习报告
2014/10/31 职场文书
大学生求职自荐信范文
2015/03/04 职场文书
死者家属慰问信
2015/03/24 职场文书
医院党建工作总结2015
2015/05/26 职场文书
幼儿园秋季开学通知
2015/07/16 职场文书
企业反腐倡廉心得体会
2015/08/15 职场文书
普希金诗歌赏析(6首)
2019/08/22 职场文书
对讲机的最大通讯距离是多少
2022/02/18 无线电