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发送伪造的arp请求
Jan 09 Python
Python使用MySQLdb for Python操作数据库教程
Oct 11 Python
浅谈python中的getattr函数 hasattr函数
Jun 14 Python
python利用lxml读写xml格式的文件
Aug 10 Python
python 打印直角三角形,等边三角形,菱形,正方形的代码
Nov 21 Python
Python使用googletrans报错的解决方法
Sep 25 Python
python3.7 使用pymssql往sqlserver插入数据的方法
Jul 08 Python
python的几种矩阵相乘的公式详解
Jul 10 Python
python IDLE 背景以及字体大小的修改方法
Jul 12 Python
让你的Python代码实现类型提示功能
Nov 19 Python
Python FtpLib模块应用操作详解
Dec 12 Python
Django自带用户认证系统使用方法解析
Nov 12 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制作新闻系统的思路
2006/10/09 PHP
PHP 飞信好友免费短信API接口开源版
2010/07/22 PHP
关于访问控制的一首PHP面试题(对属性或方法的访问控制)
2012/09/13 PHP
php自定义apk安装包实例
2014/10/20 PHP
php使用memcoder将视频转成mp4格式的方法
2015/03/12 PHP
初识ThinkPHP控制器
2016/04/07 PHP
PHP中类与对象功能、用法实例解读
2020/03/27 PHP
ExtJs扩展之GroupPropertyGrid代码
2010/03/05 Javascript
用js+iframe形成页面的一种遮罩效果的具体实现
2013/12/31 Javascript
js数值计算时使用parseInt进行数据类型转换(jquery)
2014/10/07 Javascript
jquery手风琴特效插件
2015/02/04 Javascript
js实现获取div坐标的方法
2015/11/16 Javascript
ES6学习教程之Map的常用方法总结
2017/08/03 Javascript
利用纯JS实现像素逐渐显示的方法示例
2017/08/14 Javascript
详解使用vscode+es6写nodejs服务端调试配置
2017/09/21 NodeJs
深入理解node.js http模块
2018/01/24 Javascript
vue导出html、word和pdf的实现代码
2018/07/31 Javascript
微信小程序开发之tabbar图标和颜色的实现
2018/10/17 Javascript
详解Nodejs get获取远程服务器接口数据
2019/03/26 NodeJs
图解NodeJS实现登录注册功能
2019/09/16 NodeJs
JS实现audio音频剪裁剪切复制播放与上传(步骤详解)
2020/07/28 Javascript
Nodejs 微信小程序消息推送的实现
2021/01/20 NodeJs
[02:20]DOTA2亚洲邀请赛 IG战队出场宣传片
2015/02/07 DOTA
python处理csv中的空值方法
2018/06/22 Python
python并发编程多进程 互斥锁原理解析
2019/08/20 Python
打印tensorflow恢复模型中所有变量与操作节点方式
2020/05/26 Python
软件测试常见笔试题
2012/02/04 面试题
家长写给老师的建议书
2014/03/13 职场文书
求职者怎样写自荐信
2014/04/13 职场文书
打架赔偿协议书范本
2014/10/26 职场文书
个人事迹材料范文
2014/12/29 职场文书
第28个世界无烟日活动总结
2015/02/10 职场文书
大学生求职自荐信
2015/03/24 职场文书
golang 实现Location跳转方式
2021/05/02 Golang
JavaScript事件的委托(代理)的用法示例详解
2022/02/18 Javascript
MySQL表字段数量限制及行大小限制详情
2022/07/23 MySQL