python實(shí)現(xiàn)比對(duì)美團(tuán)接口返回?cái)?shù)據(jù)和本地mongo數(shù)據(jù)是否一致示例
本文實(shí)例講述了python實(shí)現(xiàn)比對(duì)美團(tuán)接口返回?cái)?shù)據(jù)和本地mongo數(shù)據(jù)是否一致。分享給大家供大家參考,具體如下:
應(yīng)用背景:美團(tuán)平臺(tái)商品的上下架狀態(tài)、庫(kù)存、售價(jià),和mongo庫(kù)存儲(chǔ)的是否一致。
tools文件內(nèi)容
# -*- 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():#獲取當(dāng)前的時(shí)間戳
t = time.time()
return int(t)
def req_get_result(api_url,api_data):#get方法請(qǐng)求函數(shù)
req_get = requests.get(api_url,api_data)
result = req_get.json()
return result
def req_post_result(api_url,api_data):#post方法請(qǐng)求函數(shù)
req_post = requests.post(api_url,data=api_data)
result = req_post.json()
return result
def file_edit(file_name,wr_str):#寫(xiě)入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):#獲取門(mén)店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]#去掉最后一個(gè)非門(mén)店id元素
return shop_id_list
def get_shop_detail(shop_id):#根據(jù)門(mén)店id,返回門(mén)店名稱
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):#根據(jù)門(mén)店id,查詢門(mén)店商品,返回列表
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)) +'個(gè)商品'
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+"售價(jià)不一致,美團(tuán):"+skus['price']+',數(shù)據(jù)庫(kù):'+str(shopPrice)
file_edit(file_name,wirte_price)
if float(skus['stock']) != stock:
wirte_stock = sku_id+"庫(kù)存不一致,美團(tuán):"+skus['stock']+',數(shù)據(jù)庫(kù):'+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+":狀態(tài)不一致,美團(tuán):"+is_sold+',數(shù)據(jù)庫(kù):'+is_sold_out
file_edit(file_name,wirte_sold)
print('已完成',sku_id)
client.close()
更多關(guān)于Python相關(guān)內(nèi)容可查看本站專(zhuān)題:《Python Socket編程技巧總結(jié)》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門(mén)與進(jìn)階經(jīng)典教程》及《Python文件與目錄操作技巧匯總》
希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。
相關(guān)文章
python tkinter中的錨點(diǎn)(anchor)問(wèn)題及處理
這篇文章主要介紹了python tkinter中的錨點(diǎn)(anchor)問(wèn)題及處理方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-06-06
python利用pymysql和openpyxl實(shí)現(xiàn)操作MySQL數(shù)據(jù)庫(kù)并插入數(shù)據(jù)
這篇文章主要為大家詳細(xì)介紹了如何使用Python連接MySQL數(shù)據(jù)庫(kù),并從Excel文件中讀取數(shù)據(jù),將其插入到MySQL數(shù)據(jù)庫(kù)中,有需要的小伙伴可以參考一下2023-10-10
Python時(shí)間序列處理之ARIMA模型的使用講解
今天小編就為大家分享一篇關(guān)于Python時(shí)間序列處理之ARIMA模型的使用講解,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-04-04
用python寫(xiě)爬蟲(chóng)簡(jiǎn)單嗎
在本篇內(nèi)容里小編給大家整理的是關(guān)于用python寫(xiě)爬蟲(chóng)是否簡(jiǎn)單的相關(guān)內(nèi)容文章,需要的朋友們可以學(xué)習(xí)下。2020-07-07
python中pd.cut()與pd.qcut()的對(duì)比及示例
本文主要介紹了python中pd.cut()與pd.qcut()的對(duì)比及示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06

