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之入门(三)序列
May 25 Python
利用Python实现图书超期提醒
Aug 02 Python
详解python进行mp3格式判断
Dec 23 Python
python dict 字典 以及 赋值 引用的一些实例(详解)
Jan 20 Python
Python构建XML树结构的方法示例
Jun 30 Python
python 3.0 模拟用户登录功能并实现三次错误锁定
Nov 01 Python
Python Xml文件添加字节属性的方法
Mar 31 Python
Python numpy.array()生成相同元素数组的示例
Nov 12 Python
python读取并定位excel数据坐标系详解
Jun 26 Python
python模块常用用法实例详解
Oct 17 Python
Python制作一个仿QQ办公版的图形登录界面
Sep 22 Python
Python 实现RSA加解密文本文件
Dec 30 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 发送带附件邮件示例
2014/01/23 PHP
windows7下安装php的imagick和imagemagick扩展教程
2014/07/04 PHP
PHP使用range协议实现输出文件断点续传代码实例
2014/07/04 PHP
Android AsyncTack 异步任务实例详解
2016/11/02 PHP
PHP正则判断一个变量是否为正整数的方法
2019/02/27 PHP
详解PHP队列的实现
2019/03/14 PHP
jquery 学习笔记一
2010/04/07 Javascript
javascript检查浏览器是否支持flash的实现代码
2014/08/14 Javascript
使用js实现的简单拖拽效果
2015/03/18 Javascript
TypeScript具有的几个不同特质
2015/04/07 Javascript
BootStrap的JS插件之轮播效果案例详解
2016/05/16 Javascript
详解JavaScript设计模式开发中的桥接模式使用
2016/05/18 Javascript
jQuery实现ajax的叠加和停止(终止ajax请求)
2016/08/08 Javascript
JS弹出窗口的运用与技巧大全
2016/11/01 Javascript
使用javascript做在线算法编程
2018/05/25 Javascript
微信小程序文章详情页面实现代码
2018/09/10 Javascript
angular2 NgModel模块的具体使用方法
2019/04/10 Javascript
js实现幻灯片轮播图
2020/08/14 Javascript
Vue实现计算器计算效果
2020/08/17 Javascript
全面了解Python的getattr(),setattr(),delattr(),hasattr()
2016/06/14 Python
Python正则表达式经典入门教程
2017/05/22 Python
Python中的函数作用域
2018/05/07 Python
利用Python实现原创工具的Logo与Help
2018/12/03 Python
Python pandas DataFrame操作的实现代码
2019/06/21 Python
python选取特定列 pandas iloc,loc,icol的使用详解(列切片及行切片)
2019/08/06 Python
python 数据提取及拆分的实现代码
2019/08/26 Python
Python搭建代理IP池实现存储IP的方法
2019/10/27 Python
python 实现生成均匀分布的点
2019/12/05 Python
详解如何使用rem或viewport进行移动端适配
2020/08/14 HTML / CSS
2019史上最全Database工程师题库
2015/12/06 面试题
CSMA/CD介质访问控制协议
2015/11/17 面试题
住房公积金接收函
2014/01/09 职场文书
致跳高运动员加油稿
2014/02/12 职场文书
求职者怎样写自荐信
2014/04/13 职场文书
汉语专业毕业生自荐信
2014/07/06 职场文书
某某店铺的开业庆典主持词范本
2019/11/25 职场文书