python 美团api接口对接_python实现比对美团接口返回数据和本地mongo数据是否一致示例...
本文实例讲述了python实现比对美团接口返回数据和本地mongo数据是否一致。分享给大家供大家参考,具体如下:
应用背景:美团平台商品的上下架状态、库存、售价,和mongo库存储的是否一致。
tools文件内容
# -*- coding: utf-8 -*-
import hashlib
import time
import requests
def get_md5(string):#返回字符串md5加密后的串
hl = hashlib.md5()
hl.update(string.encode('utf-8'))
return hl.hexdigest()
def get_tamp():#获取当前的时间戳
t = time.time()
return int(t)
def req_get_result(api_url,api_data):#get方法请求函数
req_get = requests.get(api_url,api_data)
result = req_get.json()
return result
def req_post_result(api_url,api_data):#post方法请求函数
req_post = requests.post(api_url,data=api_data)
result = req_post.json()
return result
def file_edit(file_name,wr_str):#写入txt文件
f1 = open(r'D:\%s.txt'%file_name,'a')
f1.write(wr_str+'\n')
f1.close()
def param_sort(param_dict):#传入字典,返回排序后并且连接好的字符串
keys_list = sorted(param_dict.keys())
rb_str = ''
for k in keys_list:
key_value = k + '=' + str(param_dict[k])
rb_str = rb_str + key_value +'&'
rb_str = rb_str[0:-1] #不保留字符串末尾的&
return rb_str
下面是主逻辑
# -*- coding: utf-8 -*-
from tools import get_tamp,get_md5,req_get_result,file_edit,param_sort
import conf
import datetime
import time
from pymongo import MongoClient
app_id = conf.appinfo[1]['app_id']
secret = conf.appinfo[1]['secret']
def get_shop_id_list(app_id,secret):#获取门店id的列表
api_url = 'http://waimaiopen.meituan.com/api/v1/poi/getids'
timestamp = get_tamp()
params_str = api_url+'?app_id=%s×tamp=%s'%(app_id,timestamp)
sig = get_md5(params_str + secret)
api_data = {
'app_id':app_id,
'sig':sig,
'timestamp':timestamp,
}
result = req_get_result(api_url,api_data)
shop_id_list = result['data']
del shop_id_list[-1]#去掉最后一个非门店id元素
return shop_id_list
def get_shop_detail(shop_id):#根据门店id,返回门店名称
api_url = 'http://waimaiopen.meituan.com/api/v1/poi/mget'
timestamp = get_tamp()
app_poi_codes = shop_id
params_str = api_url+'?app_id=%s&app_poi_codes=%s×tamp=%s'%(app_id,app_poi_codes,timestamp)
sig = get_md5(params_str + secret)
api_data = {
'app_id':app_id,
'sig':sig,
'timestamp':timestamp,
'app_poi_codes':app_poi_codes
}
result = req_get_result(api_url,api_data)
shop_name = result['data'][0]['name']
return shop_name
def get_goods(shop_id):#根据门店id,查询门店商品,返回列表
api_url = 'http://waimaiopen.meituan.com/api/v1/retail/list'
timestamp = get_tamp()
app_poi_code = shop_id
params_str = api_url+'?app_id=%s&app_poi_code=%s×tamp=%s'%(app_id,app_poi_code,timestamp)
sig = get_md5(params_str + secret)
api_data = {
'app_id':app_id,
'sig':sig,
'timestamp':timestamp,
'app_poi_code':app_poi_code
}
result = req_get_result(api_url,api_data)
return result['data']
if __name__ == '__main__':
shop_ids = get_shop_id_list(app_id,secret)
file_name = datetime.datetime.now().strftime('%Y.%m.%d.%H.%M.%S')
client = MongoClient(conf.mongo_online,conf.mongo_port)
db = client['oh-product']
collection = db.outerShopSku
for shop_id in shop_ids:
shop_name = get_shop_detail(shop_id)
goods_list = get_goods(shop_id)
wirte_shop_info = shop_id + '--' + shop_name + str(len(goods_list)) +'个商品'
file_edit(file_name,wirte_shop_info)
for i in range(0,len(goods_list)):
skus = eval(goods_list[i]['skus'])[0]
sku_id = skus['sku_id']
result = collection.find({'channel':'MeiTuan','outerShopId':shop_id,'outerSkuId':sku_id})
shopPrice = result[0]['shopPrice'] #int,单位:分
stock = result[0]['stock'] #float
is_sold_out = result[0]['status'] #str online/offline
if round(float(skus['price'])*100) != shopPrice:
wirte_price = sku_id+"售价不一致,美团:"+skus['price']+',数据库:'+str(shopPrice)
file_edit(file_name,wirte_price)
if float(skus['stock']) != stock:
wirte_stock = sku_id+"库存不一致,美团:"+skus['stock']+',数据库:'+str(stock)
file_edit(file_name,wirte_stock)
if goods_list[i]['is_sold_out'] == 0:
is_sold = 'offline'
else:
is_sold = 'online'
if is_sold != is_sold_out:
wirte_sold = sku_id+":状态不一致,美团:"+is_sold+',数据库:'+is_sold_out
file_edit(file_name,wirte_sold)
print('已完成',sku_id)
client.close()
希望本文所述对大家Python程序设计有所帮助。
python 美团api接口对接_python实现比对美团接口返回数据和本地mongo数据是否一致示例...相关推荐
- python 微信公众号网页接口调用_Python调用微信公众平台接口操作示例
本文实例讲述了Python调用微信公众平台接口操作.分享给大家供大家参考,具体如下: 这里使用的是Django,其他类似 # coding=utf-8 from django.http import ...
- python+unittest+excel接口自动化_Python+requests+unittest+excel实现接口自动化测试框架
一.框架结构: 工程目录 二.Case文件设计 三.基础包 base 3.1 封装get/post请求(runmethon.py) 1 import requests 2 import json 3 ...
- python有道字典翻译_Python 调取有道翻译接口实现在线翻译功能
有道翻译有反爬虫机制,它使用了加密技术.如果你的程序报错,你可以通过搜索.查阅资料找到解决方案:尝试把访问的网址中"/translate_o"中的"_o"删除. ...
- 接口自动化测试_Python自动化测试学习路线之接口自动化测试「模块四」
01.接口自动化测试概念 (接口测试的定义与意义;接口测试的实现方式和接口自动化的实现流程) 02.HTTP协议 (通信协议原理;HTTP与HTTP协议详解(请求,响应,请求方法,状态码).sessi ...
- python课程设计矩阵对角线之和_Python二维数组实现求出3*3矩阵对角线元素的和示例...
Python二维数组实现求出3*3矩阵对角线元素的和示例 题目:求一个3*3矩阵对角线元素之和. 程序分析:利用双重for循环控制输入二维数组,再将a[i][i]累加后输出. def two_dime ...
- python requests post 二进制流_Python的requests如何同时post图片二进制流和json数据application/octet-stream...
如何用post的方法以application/octet-stream的content-type提交json和文件呢,总是说文件类型错误 写入图片 该接口用于根据 spreadsheetToken 和 ...
- 京东接口对接流程(以下举例物流接口):
1.注册成为京东宙斯开发者 2.创建应用 控制中心 – 已经应用类型选择京东物流 – 二级应用类型选择青龙应用 注:选择的接口在和京东对接联调的时候可以咨询京东开发者 3.等待审核通过 创建好了应用后 ...
- python中label组件参数_Python tkinter(六) 标签(Label)组件的属性说明及示例
使用语法 widget = Radiobutton( master, parameter=value, ... ) master:文本框控件的父容器 parameter:文本框的参数 value:参数 ...
- java第三方接口对接_调用多个第三方接口哪一种方案更好?
目的 用户在下单的时候,会调用我们的后台服务器,我们的后台服务器又会根据不同渠道调用第三方下单接口,完成整个下单流程,但是第三方下单接口可能突然出问题或者不支持,所以目前我们每一种渠道都配置了好几种备 ...
最新文章
- R语言ggplot2可视化:ggplot2可视化使用guide_axis(check.overlap=TRUE)选项删除重叠的轴文本、跳过部分中间轴标签
- Android 7.0 WifiMonitor工作流程分析
- 二叉树的层序遍历_NC15 求二叉树的层序遍历
- 白话:服务降级与熔断的区别
- 在阿里做博士后是一种怎样的体验?
- 城市智慧停车系统方案的产品设计体系介绍
- 计算机专业会议评级,2018计算机专业工程教育认证研讨会
- 2进制 , 8进制 , 10进制 , 16进制 , 介绍 及 相互转换 及 快速转换
- 如何在MaxCompute中利用bitmap进行数据处理?
- linux 环境下 openssl 生成ecdsa公、私钥
- mysql快速部署主从复制
- 压测 broken pipe 之类
- VS2012+SQLServer2008 R2 开发工具
- 动态爱心(C/C++)
- [已解决] Could not create connection to database server.
- 英国智能机器人技术和自主系统研究发展概况
- ubuntu18 防火墙关闭_ubuntu18开启/关闭防火墙
- 冒泡排序和快速排序的效率比较
- 佛祖保佑永无BUG python版本
- JVM内存模型与内存溢出异常