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中的类与对象之描述符详解
Mar 27 Python
Python实现给qq邮箱发送邮件的方法
May 28 Python
python正则表达式的使用
Jun 12 Python
python3.4用循环往mysql5.7中写数据并输出的实现方法
Jun 20 Python
python抓取搜狗微信公众号文章
Apr 01 Python
python如果快速判断数字奇数偶数
Nov 13 Python
解决Tensorflow 内存泄露问题
Feb 05 Python
python opencv 实现读取、显示、写入图像的方法
Jun 08 Python
详解Python中import机制
Sep 11 Python
ffmpeg+Python实现B站MP4格式音频与视频的合并示例代码
Oct 21 Python
selenium+headless chrome爬虫的实现示例
Jan 08 Python
pytorch MSELoss计算平均的实现方法
May 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获取url字符串截取路径的文件名和扩展名的函数
2010/01/22 PHP
全面解读PHP的人气开发框架Laravel
2015/10/15 PHP
PHP实现防止表单重复提交功能【基于token验证】
2018/05/24 PHP
Linux下 php7安装redis的方法
2018/11/01 PHP
用 JavaScript 迁移目录
2006/12/18 Javascript
Web跨浏览器进程通信(Web跨域)
2013/04/17 Javascript
微信小程序 轮播图swiper详解及实例(源码下载)
2017/01/11 Javascript
微信小程序模板之分页滑动栏
2017/02/10 Javascript
微信小程序 setData使用方法及常用错误解决办法
2017/05/11 Javascript
基于JavaScript实现弹幕特效
2020/08/27 Javascript
angular4模块中给标签添加背景图的实现方法
2017/09/15 Javascript
vue完成项目后,打包成静态文件的方法
2018/09/03 Javascript
vue-cli 首屏加载优化问题
2018/11/06 Javascript
微信小程序实现左右列表联动
2020/05/19 Javascript
微信小程序云函数添加数据到数据库的方法
2020/03/04 Javascript
[03:42]2014DOTA2国际邀请赛 第三日比赛排位扑朔迷离
2014/07/12 DOTA
比较详细Python正则表达式操作指南(re使用)
2008/09/06 Python
Python类方法__init__和__del__构造、析构过程分析
2015/03/06 Python
python 异或加密字符串的实例
2018/10/14 Python
python圣诞树编写实例详解
2020/02/13 Python
Python键鼠操作自动化库PyAutoGUI简介(小结)
2020/05/17 Python
HTML5实现QQ聊天气泡效果
2017/06/26 HTML / CSS
关于HTML5 Placeholder新标签低版本浏览器下不兼容的问题分析及解决办法
2016/01/27 HTML / CSS
AmazeUI 输入框组的示例代码
2020/08/14 HTML / CSS
万宝龙英国官网:Montblanc手表、书写工具、皮革和珠宝
2018/10/16 全球购物
千禧酒店及度假村官方网站:Millennium Hotels and Resorts
2019/05/10 全球购物
网上商城创业计划书范文
2014/01/31 职场文书
2014年应届大学生毕业自我鉴定
2014/01/31 职场文书
2014年自愿离婚协议书范本
2014/09/25 职场文书
综治工作汇报材料
2014/10/27 职场文书
小学优秀教师先进事迹材料
2014/12/16 职场文书
三年级学生评语大全
2014/12/26 职场文书
单身申明具结书
2015/02/26 职场文书
2015年医院药剂科工作总结
2015/05/04 职场文书
沂蒙六姐妹观后感
2015/06/08 职场文书
红楼梦读书笔记
2015/06/25 职场文书