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中使用Neo4j数据库的教程
Apr 16 Python
python中OrderedDict的使用方法详解
May 05 Python
python 如何快速找出两个电子表中数据的差异
May 26 Python
python调用百度语音识别api
Aug 30 Python
python实现一个简单的ping工具方法
Jan 31 Python
Python查找最长不包含重复字符的子字符串算法示例
Feb 13 Python
详解Python读取yaml文件多层菜单
Mar 23 Python
python实现身份证实名认证的方法实例
Nov 08 Python
python DES加密与解密及hex输出和bs64格式输出的实现代码
Apr 13 Python
django queryset 去重 .distinct()说明
May 19 Python
python3读取autocad图形文件.py实例
Jun 05 Python
PyCharm上安装Package的实现(以pandas为例)
Sep 18 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
ThinkPHP V2.2说明文档没有说明的那些事实例小结
2015/07/01 PHP
Tinymce+jQuery.Validation使用产生的BUG
2010/03/29 Javascript
javascript中callee与caller的用法和应用场景
2010/12/08 Javascript
基于jQuery实现的当离开页面时出现提示的实现代码
2011/06/27 Javascript
JQueryEasyUI datagrid框架的基本使用
2013/04/08 Javascript
用js的document.write输出的广告无阻塞加载的方法
2014/06/05 Javascript
jQuery插件pagewalkthrough实现引导页效果
2015/07/05 Javascript
基于javascript实现图片左右切换效果
2016/01/25 Javascript
轻松掌握JavaScript单例模式
2016/08/25 Javascript
轻松实现js选项卡切换效果
2016/09/24 Javascript
前端设计师们最常用的JS代码汇总
2016/09/25 Javascript
AngularJS表格样式简单设置方法示例
2017/03/03 Javascript
详解node单线程实现高并发原理与node异步I/O
2017/09/21 Javascript
微信小程序模板template简单用法示例
2018/12/04 Javascript
jQuery实现鼠标放置名字上显示详细内容气泡提示框效果的方法分析
2020/04/04 jQuery
vue 使用饿了么UI仿写teambition的筛选功能
2021/03/01 Vue.js
[01:19:35]DOTA2上海特级锦标赛主赛事日 - 3 败者组第三轮#2Fnatic VS OG第二局
2016/03/05 DOTA
python使用在线API查询IP对应的地理位置信息实例
2014/06/01 Python
Python之os操作方法(详解)
2017/06/15 Python
Python 列表理解及使用方法
2017/10/27 Python
如何使用Python进行OCR识别图片中的文字
2019/04/01 Python
Python getattr()函数使用方法代码实例
2020/08/10 Python
做一个能自适应高度的textarea的示例代码
2019/09/06 HTML / CSS
印度在线内衣和时尚目的地:Zivame
2017/09/28 全球购物
大学生收银员求职信分享
2014/01/02 职场文书
项目合作协议书范本
2014/04/16 职场文书
优秀学生干部个人事迹材料
2014/06/02 职场文书
校园标语大全
2014/06/19 职场文书
2014年学习全国道德模范事迹思想汇报
2014/09/15 职场文书
广告设计专业毕业生自我鉴定
2014/09/27 职场文书
医务人员医德考评自我评价
2015/03/03 职场文书
大学生见习总结报告
2015/06/24 职场文书
授权协议书范本(3篇)
2019/10/15 职场文书
vue+spring boot实现校验码功能
2021/05/27 Vue.js
使用php的mail()函数实现发送邮件功能
2021/06/03 PHP
Python面向对象编程之类的概念
2021/11/01 Python