python实战===代码
#!/usr/bin/env python
# encoding:utf-8 import requests
import json
from conf import STORE_DICT_LIST
import time store_list = STORE_DICT_LIST
store_name = 'sandbox_001'
myaccess_token = store_list[store_name]['access_token'] class Authorize():
def __init__(self):
pass
def get_authorize(self, client_id):
"""
:return:返回授权的url + code , code 给get_token 使用
授权成功之后得到一个url: redirect_uri&code=ede9c269-10d3-44ca-88d6-53030311de04
其中,redirect_uri为在wish后台设置好的。
"""
authorize_url = "https://merchant.wish.com/oauth/authorize?client_id=%s" % client_id
req = requests.get(authorize_url)
return req.text
print req.text # def get_product_online(self,name,access_token,refresh_token,client_id,idwish_account,merchant_user_id,client_secret):
# access_token_url = "https://merchant.wish.com/api/v2/oauth/access_token"
# postdict={
# "name":name,
# "access_token":myaccess_token,
# "refresh_token":refresh_token,
# "client_id":client_id,
# "idwish_account":idwish_account,
# "merchant_user_id":merchant_user_id,
# "client_secrect":client_secret
# }
# return 1 def get_token(self, code, client_id, client_secret, redirect_uri=None):
"""
: return : 返回 json
u'{"message":"",
"code":0,
"data":{"expiry_time":1465132728,
"token_type ":"access_token",
"access_token":"84aeb5997b6d4c83a99b1a22ee6423b6",
"expires_in":2591976,"merchant_user_id":"57298cbd15abf85958e9f87a",
"refresh_token":"b0bd8eec162d4aaf87d0e6aaf43729f7"}}'
"""
if not redirect_uri:
redirect_uri = "https://localhost/"
access_token_url = "https://merchant.wish.com/api/v2/oauth/access_token" postdict = {"client_id":client_id,
"client_secret": client_secret,
"code":code,
"grant_type":"authorization_code",
"redirect_uri": redirect_uri}
print postdict
req = requests.post(access_token_url, data = postdict)
token_json = eval(req.text)
print token_json
return token_json def refresh_token(self,client_id, client_secret, refresh_token):
"""
更新token
"""
refresh_url = "https://merchant.wish.com/api/v2/oauth/refresh_token"
#refresh_url = "https://sandbox.merchant.wish.com/api/v2/oauth/refresh_token" postdict = { "client_id": client_id,
"client_secret": client_secret,
"refresh_token": refresh_token,
"grant_type": "refresh_token"
}
req = requests.post(refresh_url, data = postdict)
new_token_json = eval(req.text)
return new_token_json class Wish(object):
# https://china-merchant.wish.com/api/v2/
"""
对wish的接口api做一个整合,主要设计到产品上架相关接口
以及之后需要处理的订单下载接口
"""
def __init__(self, *access_token):
if access_token:
self.access_token = access_token
else:
self.access_token = myaccess_token
self.base_url = "https://china-merchant.wish.com/api/v2/"
# self.base_url = "https://sandbox.merchant.wish.com/api/v2/" def __make_call(self, func, **params):
"""
func: /product/add ,调用的函数 post提交
**params: 参数
"""
urls = self.base_url + func
urls = urls.split("://")
urls = urls[0] + "://" + urls[1].replace("//","/")
print "urls: ", urls
data_params = {}
data_params.update({"access_token":self.access_token})
if params:
data_params.update(**params)
req = requests.post(urls, data = data_params, verify=False)
return req.text def func_call(self, func, **params):
"""
将返回的结果变为字典,如果可以转变成字典的话
"""
result = self.__make_call(func, **params)
try:
result = json.loads(result)
except Exception, e:
# print "result: ", result
print "json loads result Error, %s" % e
result = {}
return result def query_params(self,func, params_list, **params):
""" 检查参数 """
message = ""
for param in params_list:
if not params.get(param):
message = "%s , 参数不全, 没有找到参数: %s " % (str(func), param)
break
return message #-----------------------------------------------------------------
# ---------------------- 订单相关 --------------------------------
def fetch_order_id(self, **params):
"""
func: 根据order_id来获取 订单
:param params:
{
"id": 123456789009876543210164
}
"""
func ="/order"
result = {}
if not params.get("id"):
print "input a id in params, please!"
return result
result = self.func_call(func, **params)
return result def fetch_all_order(self, **params):
"""
func: 获取所有订单
:param params:
{
"start": 0,
"limit": 100,
"since": "2016-4-1"
}
"""
func = "/order/multi-get"
result = {}
start, limit = 0, 15
since = "2016-4-1"
if params.get("start", ""): start = params.get("start")
if params.get("limit", ""): limit = params.get("limit")
if params.get("since", ""): since = params.get("since")
params = {"start": start, "count": limit, "since": since}
tmp_result = self.func_call(func, **params)
result = tmp_result
while len(tmp_result.get("data", [])) >= limit:
start += limit
print "start: ", start
tmp_result = self.func_call(func, **params)
result.get("data").extend(tmp_result.get("data",[]))
print "tmp_result: ", tmp_result
time.sleep(0.5)
return result def get_fulfill_order(self,**params):
"""
func:获取需要处理的订单
:param params:
{ }
"""
func = 'order/get-fulfill'
result ={}
start ,limit = 0,50
since = "2016-4-1"
if params.get("start", ""): start = params.get("start")
if params.get("limit", ""): limit = params.get("limit")
if params.get("since", ""): since = params.get("since")
params = {"start": start, "count": limit, "since": since}
tmp_result = self.func_call(func, **params)
result = tmp_result
print len(result)
while len(tmp_result.get("data", [])) >limit:
params ['start']=start
tmp_result = self.func_call(func, **params)
result.get("data").extend(tmp_result.get("data",[]))
time.sleep(0.5)
start +=limit return result
def cancel_order(self, **params):
"""
func: 退货,取消订单
:param params
{
"id": "", #order_id
"reason_code": 18, #取消原因的代码
"reason_note": "", #原因解释,当选择-1的时候
} :return
{
'code': 0,
'data': {'success': True},
'message': ''
} ------------------------------
-1 其他
18 误下单了
20 配送时间过长
22 商品不合适
23 收到错误的商品
24 商品为假冒伪劣品
25 商品已损坏
26 商品与描述不符
27 商品与清单不符
30 产品被配送至错误的地址
31 用户提供了错误的地址
32 商品退还至发货人
33 Incomplete Order
34 店铺无法履行订单
35 此件显示已妥投,但客户未收到。
1001 Received the wrong color
1002 Item is of poor quality
1004 Product listing is missing information
1005 Item did not meet expectations
1006 Package was empty
"""
result = {}
func = "/order/refund"
if not params.get("id") or not params.get("reason_code"):
print "参数不正确, 确保有参数id, 和reason_code"
return result
result = self.func_call(func, **params)
return result def modify_tracking(self, **params):
"""
func: 修改已装运订单的跟踪
:param params
{
"id":"", #order_id
"tracking_provider": "USPS",
"tracking_number": "12345678" #快递号
"ship_note": "给用户的注意", 可以不填写这个参数
}
"""
result = {}
func = "/order/modify-tracking"
if not params.get("id") or not params.get("tracking_provider") or not params.get("tracking_number"):
print "参数不正确,确保有{'id':'','tracking_provider':'', 'tracking_number':''} ..."
return result
result = self.func_call(func, **params)
return result def fulfile_one_order(self, **params):
"""
func: 标志为已发货
:param params
{
"id" : "57242e8c0000000000000000",
"tracking_provider" : "USPS",
"tracking_number" : "12345678" ,
} return :
{
u'message': u'Your order is being processed right now!',
u'code': 0,
u'data': {u'success': True}
}
"""
func = "/order/fulfill-one"
result = {}
if not params.get("id") or not params.get("tracking_provider") or not params.get("tracking_number"):
print "参数不正确,确保参数含有 {'id':'', 'tracing_provider':'', 'tracking_number':''} "
return result
result = self.func_call(func, **params)
return result #----------------------------------------------------------------
#------------------------- wishAPI产品相关接口 ------------------------------
"""
/product
/product/multi-get
/product/update
/product/enable
/product/disable
/product/add
/product/create-download-job
/product/get-download-job-status
/product/cancel-download-job
""" def retrieve_product(self, **params):
"""
func: 检索在wish平台上存在的产品的详细信息。
:param params
{
"id": "",
"parent_sku": "",
}
@return 返回一个产品实体 字典类型
"""
func = "/product"
result = {}
params_list = ["id", "parent_sku"]
message = self.query_params(func, params_list, **params)
if message:
result["message"] = message
return result
result = self.func_call(func, **params)
return result def product_add(self, **params):
"""
func: 添加产品
:param params
{
"name": "产品名称", #必须
"description": "产品描述", #必须
"tags": "关键字", #必须
"sku": "sku", #必须
"color": "颜色", #可选,部分没有
"size": "尺寸", #可选
"inventory": "库存", #必须
"price": "", #必须
"shipping": "配送", #必须
"msrp":"可选的制造商建议零售价",
"shipping_time": "时间",
"main_image": "", #必须
"parent_sku": "",
"brand": "产品厂商或牌子",
"landing_page_url": "登入页码链接",
"upc": "商品条码",
"extra_images": "其他的图片", #用了 '|' 分割
}
"""
func = "/product/add"
result = {}
params_list = ["name", "description", "tags", "sku", "inventory", "price", "main_image", "shipping"]
message = self.query_params(func, params_list, **params)
if message:
result["message"] = message
return result
result = self.func_call(func, **params)
print result
return result def update_product(self, **params):
"""
func : 更新产品信息, 更新name,description, tags
:param params
{
"id": "", #必须
"parent_sku": "", #必须
"name": "",
"description": "",
"tags": "",
"brand": "",
"landing_page_url": "",
"upc": "",
"main_image": "",
"extra_images": "",
}
"""
func = "/product/update"
result = {}
params_list = ["id", "parent_sku"]
message = self.query_params(func, params_list, **params)
if message:
result["message"] = message
return result
result = self.func_call(func, **params)
return result def enable_product(self, **params):
"""
func: 使一个产品可以出售
:param params
{
"id": "",
"parent_sku": ""
}
"""
func = "/product/enable"
result = {}
params_list = ["id", "parent_sku"]
message = self.query_params(func, params_list, **params)
if message:
result["message"] = message
return result
result = self.func_call(func, **params)
return result def disable_product(self, **params):
"""
func: 停止一个产品可出售
:param params
{
"id": "",
"parent_sku": "",
}
"""
func = "/product/disable"
params_list = ["id", "parent_sku"]
result = {}
message = self.query_params(func, params_list, **params)
if message:
result["message"] = message
return result
result = self.func_call(func, **params)
return result
def list_all_products(self, **params):
"""
func: 列出所有产品
:param params
{
"start": "0",
"limit": "30",
"since": "2016-4-1",
}
"""
result = {}
func = "/product/multi-get"
start, limit = 0, 15
since = "2016-4-1"
if params.get("start", ""): start = params.get("start")
if params.get("limit", ""): limit = params.get("limit")
if params.get("since", ""): since = params.get("since")
params = {"start": start, "count": limit, "since": since}
tmp_result = self.func_call(func, **params)
result = tmp_result
while len(tmp_result.get("data", [])) >= limit:
start += limit
print "start: ", start
tmp_result = self.func_call(func, **params)
result.get("data").extend(tmp_result.get("data",[]))
print "tmp_result: ", tmp_result
time.sleep(0.5)
return result def remove_extra_images(self, **params):
"""
func: 移除extra图片
:param params
{
"id":"", #产品id
"parent_sku":"",
}
"""
result = {}
func = "/product/remove-extra-images"
params_list = ["id", "parent_sku"]
message = self.query_params(func, params_list, **params)
if message:
result["message"] = message
return result
result = self.func_call(func, **params)
return result #----------------------------------------------------------------------------
#------------------------------ 创建新产品属性相关 -------------------------- def variant_add(self, **params):
"""
func: 属性添加。比如已经有一个产品有红色属性,但是想添加一个size=12的属性,则用此api
:param params
{
"parent_sku": "产品名称", #必须
"sku": "sku", #必须
"color": "颜色", # 颜色与尺寸,不能同时为空
"size": "尺寸", #
"inventory": "库存", #必须
"price": "", #必须
"shipping": "配送", #必须
"msrp":"可选的制造商建议零售价",
"shipping_time": "时间",
"main_image": "",
}
""" func = "/variant/add"
result = {}
params_list = ["parent_sku", "sku", "inventory", "price", "shipping"]
message = self.query_params(func, params_list, **params)
if message:
result["message"] = message
result = self.func_call(func, **params)
return result def variant_retrieve(self, **params):
"""
func: 想查看一个商品的状态
:param params
{
"sku":"",
}
"""
func = "/variant"
result = {}
params_list = ["sku"]
message = self.query_params(func, params_list, **params)
if message:
result["message"] = message
return result
result = self.func_call(func, **params)
return result def enable_variant_product(self, **params):
"""
func: 让一个变体产品可用
:param params
{
"sku" : "",
}
"""
func = "/variant/enable"
result = {}
params_list = ["sku"]
message = self.query_params(func, params_list, **params)
if message:
result["message"] = message
return result
result = self.func_call(func, **params)
return result
def disable_variant_product(self, **params):
"""
func: 变体产品不可用
:param params
{
"sku": ""
}
"""
func = "/variant/disable"
result = {}
params_list = ["sku"]
message = self.query_params(func, params_list, **params)
if message:
result["message"] = message
return result
result = self.func_call(func, **params)
return result def change_product_sku(self, **params):
"""
func: 修改sku
:param params
{
"sku":"",
"new_sku": "",
}
"""
result = {}
func = "/variant/change-sku"
params_list = ["sku", "new_sku"]
message = self.query_params(func, params_list, **params)
if message:
result["message"] = message
return result
result = self.func_call(func, **params)
return result def update_inventory(self, **params):
"""
func: 更新库存
:param params
{
"sku": "",
"inventory": "",
}
"""
result = {}
func = "/variant/update-inventory"
params_list = ["sku", "inventory"]
message = self.query_params(func, params_list, **params)
if message:
result["message"] = message
return result
result = self.func_call(func, **params)
return result def list_all_variations(self, **params):
"""
func: 列出所有变化的产品
:param params
{
"start": "",
"limit": "",
}
"""
func = "/variant/multi-get"
result = {}
params_list = ["start", "limit"]
start, limit = 0, 15
if params.get("start", ""): start = params.get("start")
if params.get("limit", ""): limit = params.get("limit")
params = {"start": start, "count": limit}
tmp_result = self.func_call(func, **params)
result = tmp_result
while len(tmp_result.get("data", [])) >= limit:
start += limit
print "start: ", start
tmp_result = self.func_call(func, **params)
result.get("data").extend(tmp_result.get("data",[]))
print "tmp_result: ", tmp_result
time.sleep(0.5)
return result #----------------------------------------------------------------------------
#------------------------------上传一个图片 ----------------------------------
def upload_image(self, **params):
"""
func: 上传图片
:param params
{
"image": "ABCD1234abcd", #Base64编码
}
"""
func = "/image"
result = {}
params_list = ["image"]
message = self.query_params(func, params_list, **params)
if message:
result["message"] = message
return result
result = self.func_call(func, **params)
return result #----------------------------------------------------------------------------
#------------------------------用户认证测试 --------------------------------
def auth_test(self):
func = "/auth_test" #在前面要加 '/'
req = self.func_call(func)
print req def main():
store_list = STORE_DICT_LIST
store_name = 'sandbox_001'
print store_list[store_name]
wish = Wish(store_list[store_name]['access_token']) wish.auth_test()
"""
all_order_result = wish.fetch_all_order()
print "all_order_result: ", all_order_result # 根据id取得订单
params = {'id':'57242e8c0000000000000000'}
one_order_result = wish.fetch_order_id(**params)
print one_order_result #取消订单
params = {'id': '5728230c0000000000000000', 'reason_code': 18}
cancel_result = wish.cancel_order(**params)
print cancel_result #修改已装运订单的跟踪, 此订单为历史记录里面
params = {
"id":"5722dd0c0000000000000000", #order_id
"tracking_provider": "USPS",
"tracking_number": "12345678", #快递号
"ship_note": "给用户的注意", #可以不填写这个参数
}
result = wish.modify_tracking(**params)
print result # 标志为已发货
params = {
"id" : "57242e8c0000000000000000",
"tracking_provider" : "USPS",
"tracking_number" : "12345678" ,
}
fulfile_result = wish.fulfile_one_order(**params)
print fulfile_result
"""
#------------------------------------------------------------- params = {
"name": "myshipping", #必须
"description": "this is a cool shoe, it's very bueatiful!", #必须
"tags": "red, shoe, cool, myship",
"parent_sku": "skudkjasfabcfc", #必须 #父sku,变体的产品必须
"sku": "skudkjasfabcfc-red-22", #必须
"color": "red", #可选,部分没有
"size": "", #可选
"inventory": "", #必须
"price": "", #必须
"shipping": "", #必须
"msrp":"",
"main_image": "https://dfk8hf9p19dtk.cloudfront.net/E/EL61365P6610-1.jpg", #必须
"parent_sku": "parent-sku_manmansku",
"brand": "shipped",
"landing_page_url": "https://dfk8hf9p19dtk.cloudfront.net/E/EL61365P6610-2.jpg",
"upc": "abc123",
"extra_images": "https://dfk8hf9p19dtk.cloudfront.net/E/EL61365P6610-3.jpg|https://dfk8hf9p19dtk.cloudfront.net/E/EL61365P6610-2.jpg", #用了 '|' 分割
}
# result = wish.product_add(**params)
result = wish.variant_add(**params)
print result
if result.get("code") == 0:
if result.get("data").get("Product"):
print "product_id:", result.get("data").get("Product").get("variants")[0].get("Variant").get("product_id")
else:
print "variation id:", result.get("data").get("Variant").get("product_id")
print "current id: ", result.get("data").get("Variant").get("id")
else:
print "message: ", result.get("message")
"""
## 查看产品信息
params = {"id": "572d9ebeae24f05a7962eee2", "parent_sku":"parent-sku"}
result = wish.retrieve_product(**params)
print result ## 更新产品信息
params = {
"id": "572d9ebeae24f05a7962eee2", #必须
"parent_sku": "parent-sku", #必须
"name": "产品名称",
"description": "it's new update description, color: red, size: 200*200",
"tags": "new, tags1, tags2",
"brand": "无牌子",
"landing_page_url": "http://img.alicdn.com/tps/TB1sNzAJFXXXXcDXpXXXXXXXXXX-1920-450.jpg",
"upc": "30",
"main_image": "http://img.alicdn.com/tps/TB1sNzAJFXXXXcDXpXXXXXXXXXX-1920-450.jpg",
"extra_images": "http://img.alicdn.com/tps/TB1sNzAJFXXXXcDXpXXXXXXXXXX-1920-450.jpg",
}
result = wish.update_product(**params) ## 列出所有产品信息
result = wish.list_all_products()
print result
""" ## 列出所有变更过的产品
#result = wish.list_all_variations()
#print result if __name__ == "__main__":
# main()
code ='3ff343daafd847d980de7bbdd4b9bcab'
client_id='5795739b09815726c88a47f0'
client_secret='9e404f3916604fbcbd2f1d29eb078e31'
redirect_uri='https://localhost/'
aa = Authorize()
aa.get_token(code=code, client_id=client_id, client_secret = client_secret, redirect_uri=redirect_uri)
python实战===代码的更多相关文章
- python实战:用70行代码写了一个山炮计算器!
python实战训练:用70行代码写了个山炮计算器! 好了...好了...各位因为我是三年级而发牢骚的各位伙伴们,我第一次为大家插播了python的基础实战训练.这个,我是想给,那些python基础一 ...
- Python实战:美女图片下载器,海量图片任你下载
Python应用现在如火如荼,应用范围很广.因其效率高开发迅速的优势,快速进入编程语言排行榜前几名.本系列文章致力于可以全面系统的介绍Python语言开发知识和相关知识总结.希望大家能够快速入门并学习 ...
- Python实战:Python爬虫学习教程,获取电影排行榜
Python应用现在如火如荼,应用范围很广.因其效率高开发迅速的优势,快速进入编程语言排行榜前几名.本系列文章致力于可以全面系统的介绍Python语言开发知识和相关知识总结.希望大家能够快速入门并学习 ...
- python实战--数据结构二叉树
此文将讲述如何用python实战解决二叉树实验 前面已经讲述了python语言的基本用法,现在让我们实战一下具体明确python的用法 点击我进入python速成笔记 先看一下最终效果图: 首先我们要 ...
- 再一波Python实战项目列表
前言: 近几年Python可谓是大热啊,很多人都纷纷投入Python的学习中,以前我们实验楼总结过多篇Python实战项目列表,不但有用还有趣,最主要的是咱们实验楼不但有详细的开发教程,更有在线开发环 ...
- python实战博客
2018-10-31 更新Logging日志记录以及异常捕获 感谢廖大教程.Python实战 直接在闲置的服务器上开发.阿里云Centos 6.8 64位. 1 搭建开发环境 Python 环境是Py ...
- 原创:centos7.1下 ZooKeeper 集群安装配置+Python实战范例
centos7.1下 ZooKeeper 集群安装配置+Python实战范例 下载:http://apache.fayea.com/zookeeper/zookeeper-3.4.9/zookeepe ...
- 自然语言处理之中文分词器-jieba分词器详解及python实战
(转https://blog.csdn.net/gzmfxy/article/details/78994396) 中文分词是中文文本处理的一个基础步骤,也是中文人机自然语言交互的基础模块,在进行中文自 ...
- 零基础入门Python实战:四周实现爬虫网站 Django项目视频教程
点击了解更多Python课程>>> 零基础入门Python实战:四周实现爬虫网站 Django项目视频教程 适用人群: 即将毕业的大学生,工资低工作重的白领,渴望崭露头角的职场新人, ...
随机推荐
- jstack分析线程死锁
一.介绍 jstack是java虚拟机自带的一种堆栈跟踪工具.jstack用于打印出给定的java进程ID或core file或远程调试服务的Java堆栈信息,如果是在64位机器上,需要指定选项&qu ...
- bootstrap 有些控件需要调用锚点,会与angular 路由 冲突
最简单的方法 就是 在 #号前加/, 但有人说 在服务器上回失效,也不知道是什么原理.慎用 最靠谱的方法 就 是 使用bootstrap中的js控制控件, 比如轮播图的上一页 下一页,就可以在 ang ...
- powerdesigner 点击preview 语句出现 if exists
drop table if exists XXX 这个是sql server 写法.如果要切换为 Oracle 写法 菜单栏: database-->change curren DBMS 选择你 ...
- 【转】OSI详解
本文转自牛客网友CZ❤♡ღQM对在ISO/OSI参考模型中,网络层的主要功能是一题的回答. OSI ( Open System Interconnect ),即开放式系统互联. 一般都叫 OSI 参考 ...
- MySQL中数据表的基本操纵
本文基于对国家863中部软件孵化器编著的<MySQL从入门到精通>一书的操作实践. 一.创建数据表 数据表属于数据库,在创建数据表之前,应该使用语句 USE 数据库名 指定操作是在那个 ...
- IT英语累积
JPA: Java Persistence API 一种持久化规范 Spring Data:一种用于简化数据库访问,支持云服务的开源框架 Spring Data JPA:是Spring Data的 ...
- "HK"日常之冻结术
在那遥远的MSDN上,有那么一只被隐藏的函数,它掌管着Windows内核威力不容小觑~ 本教程仅作为学习研究,禁止其他用途! 富强.民主.文明.和谐, 自由.平等.公正.法治, 爱国.敬业.诚信.友善 ...
- 关于xml文件头部xmlsn
样本: <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://ww ...
- 二叉树中和为某一值得路径 java实现
本题来自<剑指offer> 路径为从根节点到叶节点一条路径,路径经过的各节点数值之和等于某一给定数值,则打印路径上的节点 因为需要打印满足条件的路径节点信息和各节点之和,需要栈记录经过的节 ...
- select和epoll概念
关于linux的I/O复用接口select和epoll,下列说法错误的是() select调用时会进行线性遍历,epoll采用回调函数机制,不需要线性遍历 select的最大连接数为FD_SETSIZ ...