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中生成器和yield语句的用法详解
Apr 17 Python
Python中列表元素转为数字的方法分析
Jun 14 Python
浅谈django model postgres的json字段编码问题
Jan 05 Python
Python实现PS滤镜功能之波浪特效示例
Jan 26 Python
Python(TensorFlow框架)实现手写数字识别系统的方法
May 29 Python
Win10环境python3.7安装dlib模块趟过的坑
Aug 01 Python
Pycharm 字体大小调整设置的方法实现
Sep 27 Python
keras用auc做metrics以及早停实例
Jul 02 Python
Python 如何测试文件是否存在
Jul 31 Python
Python通过类的组合模拟街道红绿灯
Sep 16 Python
python 实现倒计时功能(gui界面)
Nov 11 Python
Django+Celery实现定时任务的示例
Jun 23 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/03 咖啡文化
PHP分页显示制作详细讲解
2006/12/05 PHP
php下删除字符串中HTML标签的函数
2008/08/27 PHP
php正则preg_replace_callback函数用法实例
2015/06/01 PHP
完美解决IE低版本不支持call与apply的问题
2013/12/05 Javascript
javascript通过className来获取元素的简单示例代码
2014/01/10 Javascript
自己用jQuery写了一个图片的马赛克消失效果
2014/05/04 Javascript
jQuery实现折线图的方法
2015/02/28 Javascript
yui3的AOP(面向切面编程)和OOP(面向对象编程)
2015/05/01 Javascript
JS+CSS实现大气清新的滑动菜单效果代码
2015/10/22 Javascript
JavaScript截取、切割字符串的技巧
2016/01/07 Javascript
javascript设计模式之中介者模式学习笔记
2017/02/15 Javascript
vue.js获取数据库数据实例代码
2017/05/26 Javascript
vue中遇到的坑之变化检测问题(数组相关)
2017/10/13 Javascript
node.js读取Excel数据(下载图片)的方法示例
2018/08/02 Javascript
详解Vue的常用指令v-if, v-for, v-show,v-else, v-bind, v-on
2018/10/12 Javascript
Vue中的情侣属性$dispatch和$broadcast详解
2019/03/07 Javascript
JS定义函数的几种常用方法小结
2019/05/23 Javascript
js实现无缝滚动双图切换效果
2019/07/09 Javascript
javascript删除数组元素的七个方法示例
2019/09/09 Javascript
Vue实现点击导航栏当前标签后变色功能
2020/08/19 Javascript
[51:44]2018DOTA2亚洲邀请赛 4.3 突围赛 Optic vs iG 第二场
2018/04/04 DOTA
探究Python中isalnum()方法的使用
2015/05/18 Python
python图像和办公文档处理总结
2019/05/28 Python
使用Python制作缩放自如的圣诞老人(圣诞树)
2019/12/25 Python
CSS实现半透明边框与多重边框的场景分析
2019/11/13 HTML / CSS
Dodax奥地利:音乐、电影、书籍、玩具、电子产品等
2019/08/31 全球购物
产品工艺师的岗位职责
2013/11/15 职场文书
英语专业学生个人求职信
2014/01/28 职场文书
项目投资意向书
2014/04/01 职场文书
国庆节演讲稿
2014/05/27 职场文书
节能环保口号
2014/06/12 职场文书
食品安全处置方案
2014/06/14 职场文书
临时用工协议书范本
2014/10/29 职场文书
家庭教育培训学习心得体会
2016/01/14 职场文书
vue的项目如何打包上线
2022/04/13 Vue.js