淘宝 API(taobao.item.get) Python 调用 + 解析 + 数据反馈参考

简介: 下面给你一套可直接运行的淘宝 API Python 调用 + 解析 + 数据反馈参考,以最常用的 ** 商品详情(taobao.item.get)和商品搜索(taobao.item.search)** 为例,包含完整签名、请求、JSON 返回、解析代码与字段说明。

下面给你一套可直接运行的淘宝 API Python 调用 + 解析 + 数据反馈参考,以最常用的 ** 商品详情(taobao.item.get)商品搜索(taobao.item.search)** 为例,包含完整签名、请求、JSON 返回、解析代码与字段说明。


一、前置准备

  1. 注册淘宝开放平台 → 创建应用 → 获取 AppKey / AppSecret
  2. 安装依赖

bash

运行

pip install requests pycryptodome
  1. 网关地址:

二、Python 调用与解析完整代码(通用版)

1. 签名工具(必须)

python

运行

import hashlib
import requests
import json
from datetime import datetime
def generate_sign(params, app_secret):
    """生成淘宝API签名(MD5)"""
    sorted_params = sorted(params.items(), key=lambda x: x[0])
    query = ''.join([f"{k}{v}" for k, v in sorted_params])
    sign_str = app_secret + query + app_secret
    return hashlib.md5(sign_str.encode('utf-8')).hexdigest().upper()
def call_taobao_api(method, app_key, app_secret, biz_params):
    """通用淘宝API调用函数"""
    base_url = "https://gw.api.taobao.com/router/rest"
    public_params = {
        "method": method,
        "app_key": app_key,
        "timestamp": datetime.now().strftime("%Y-%m-%d %H:%M:%S"),
        "format": "json",
        "v": "2.0",
        "sign_method": "md5"
    }
    all_params = {**public_params, **biz_params}
    all_params["sign"] = generate_sign(all_params, app_secret)
    
    try:
        resp = requests.post(base_url, data=all_params, timeout=10)
        resp.raise_for_status()
        return resp.json()
    except Exception as e:
        print(f"请求失败: {e}")
        return None

三、示例 1:商品详情(taobao.item.get)

1. 调用代码

python

运行

# 配置
APP_KEY = "你的AppKey"
APP_SECRET = "你的AppSecret"
NUM_IID = "650088223456"  # 商品ID
# 业务参数
biz_params = {
    "num_iid": NUM_IID,
    "fields": "num_iid,title,price,original_price,pic_url,volume,location,skus,detail_url"
}
# 调用API
result = call_taobao_api("taobao.item.get", APP_KEY, APP_SECRET, biz_params)

2. 标准 JSON 返回(简化)

json

{
  "item_get_response": {
    "item": {
      "num_iid": "650088223456",
      "title": "2025新款智能手表 高清大屏 运动健康监测",
      "price": "1299.00",
      "original_price": "1599.00",
      "pic_url": "https://img.alicdn.com/bao/uploaded/i1/xxx.jpg",
      "volume": "2000",
      "location": {
        "city": "深圳",
        "state": "广东"
      },
      "detail_url": "https://item.taobao.com/item.htm?id=650088223456",
      "skus": [
        {
          "sku_id": "123456789",
          "price": "1299.00",
          "stock": 150,
          "properties_name": "颜色:黑色;尺寸:42mm"
        },
        {
          "sku_id": "123456790",
          "price": "1399.00",
          "stock": 80,
          "properties_name": "颜色:银色;尺寸:46mm"
        }
      ]
    },
    "request_id": "abc123xyz"
  }
}

3. Python 解析代码

python

运行

def parse_item_detail(json_data):
    """解析商品详情"""
    if "error_response" in json_data:
        print(f"错误: {json_data['error_response']['msg']}")
        return None
    
    item = json_data["item_get_response"]["item"]
    parsed = {
        "商品ID": item["num_iid"],
        "标题": item["title"],
        "售价": float(item["price"]),
        "原价": float(item.get("original_price", 0)),
        "主图": item["pic_url"],
        "销量": int(item["volume"]),
        "发货地": f"{item['location']['state']} {item['location']['city']}",
        "商品链接": item["detail_url"],
        "SKU列表": []
    }
    
    for sku in item.get("skus", []):
        parsed["SKU列表"].append({
            "SKU_ID": sku["sku_id"],
            "规格": sku["properties_name"],
            "价格": float(sku["price"]),
            "库存": sku["stock"]
        })
    return parsed
# 解析并打印
if result:
    item_detail = parse_item_detail(result)
    print(json.dumps(item_detail, indent=2, ensure_ascii=False))

四、示例 2:商品搜索(taobao.item.search)

1. 调用代码

python

运行

biz_params = {
    "q": "智能手表",
    "page_no": "1",
    "page_size": "20",
    "fields": "num_iid,title,price,pic_url,volume,provcity"
}
result = call_taobao_api("taobao.item.search", APP_KEY, APP_SECRET, biz_params)

2. JSON 返回(简化)

json

{
  "item_search_response": {
    "items": {
      "item": [
        {
          "num_iid": "650088223456",
          "title": "2025新款智能手表 高清大屏",
          "price": "1299.00",
          "pic_url": "https://img.alicdn.com/xxx.jpg",
          "volume": "2000",
          "provcity": "广东 深圳"
        },
        {
          "num_iid": "650088223457",
          "title": "运动智能手表 心率监测",
          "price": "899.00",
          "pic_url": "https://img.alicdn.com/yyy.jpg",
          "volume": "1500",
          "provcity": "浙江 杭州"
        }
      ]
    },
    "total_results": 1000,
    "request_id": "def456uvw"
  }
}

3. 解析代码

python

运行

def parse_item_search(json_data):
    """解析商品搜索结果"""
    if "error_response" in json_data:
        print(f"错误: {json_data['error_response']['msg']}")
        return None
    
    items = json_data["item_search_response"]["items"]["item"]
    parsed_list = []
    for item in items:
        parsed_list.append({
            "商品ID": item["num_iid"],
            "标题": item["title"],
            "价格": float(item["price"]),
            "主图": item["pic_url"],
            "销量": int(item["volume"]),
            "发货地": item["provcity"]
        })
    return parsed_list
# 解析
if result:
    search_result = parse_item_search(result)
    print(f"搜索到 {len(search_result)} 个商品")
    print(json.dumps(search_result[:2], indent=2, ensure_ascii=False))

五、常见错误返回(必须处理)

json

{
  "error_response": {
    "code": 10001,
    "msg": "Invalid signature",
    "sub_code": "isv.sign-invalid",
    "sub_msg": "签名无效"
  }
}
  • 10001:签名错误(检查排序 / 拼接 / 密钥)
  • 40004:缺少必填参数
  • 40006:权限不足(未开通接口)
  • 50000:服务器异常

六、核心字段说明(常用)

表格

字段 含义 类型
num_iid 商品 ID string
title 商品标题 string
price 售价 string(需转 float)
original_price 原价 string
pic_url 主图 string
volume 销量 string(需转 int)
skus SKU 列表 array
location 发货地 object
provcity 发货地(省 + 市) string
相关文章
|
2月前
|
数据采集 JSON 监控
淘宝商品详情 API 全解析 —— 从接口调用到 JSON 返回数据实战
在电商数据采集、竞品分析、价格监控、选品决策等场景中,淘宝商品详情 API是最核心、最常用的数据接口。它能稳定获取商品标题、价格、销量、库存、SKU 规格、店铺信息、发货地、好评率等全维度数据,相比直接爬虫,API 调用更合规、更稳定、效率更高。
|
3月前
|
XML JSON API
淘宝商品详情API(tb.item_get)
本文详解淘宝开放平台商品详情核心API(如item_get),涵盖对接流程、权限申请、请求规范、参数说明及返回字段,并列举代购集运、选品分析、比价导购等典型应用场景,助力开发者合规高效获取商品数据。(239字)
|
3月前
|
数据采集 监控 API
合法获取淘宝商品数据:通过淘宝开放平台API的实践指南
本文介绍通过淘宝开放平台官方API合法获取商品数据的完整流程,强调禁止爬虫、遵守协议,确保合规调用商品详情、搜索等接口,规避法律与封号风险。
|
1月前
|
人工智能 Linux API
OpenClaw搭建金融投研Agent:接入QVeris一键接入万级数据源+阿里云/本地部署与模型配置教程
普通投资者日常投研普遍面临三大痛点:多平台切换耗时、信息零散难汇总、AI频繁编造数据导致结论不可信。OpenClaw搭配QVeris技能后,可一次性接入上万级真实数据源,覆盖股票、金价、财报、行业、宏观、新闻、研报等全维度投研信息,且所有数据可溯源、可验证,彻底解决AI幻觉问题。本文完整保留QVeris核心能力、六大投研场景、三步安装流程,同时新增**2026阿里云轻量服务器部署**、**Windows11/MacOS/Linux本地部署**、**阿里云千问API配置**、**免费Coding Plan对接**,并提供可直接复制的代码命令、高频问题与避坑方案
931 14
|
1月前
|
数据采集 JSON 网络协议
淘宝评论api调用常见问题以及解决方案?
淘宝评论 API(核心为taobao.item.reviews.get)调用常见问题集中在权限、签名、限流、参数、数据、网络、解析、合规八大类,以下按问题类型逐一说明现象、原因、解决方案与最佳实践,附错误码速查。
|
2月前
|
缓存 监控 算法
淘宝商品详情 API 接入全流程实战指南 (附完整代码)
item_get 是淘宝开放平台提供的核心商品详情查询接口,支持通过商品 ID(num_iid)获取淘宝/天猫商品的完整结构化数据,包括:
|
30天前
|
数据可视化 Python
365Nimbus图像解析相机系统可见光图像L1,HDF5 V001
Nimbus图像解析相机系统(IDCS)L1级可见光图像数据集,源自Nimbus-3/4卫星,提供HDF5格式黑白影像,支持地理空间搜索与可视化分析。
51 2
|
30天前
|
SQL 安全 PHP
PHP安全防护全攻略:规避风险,守护应用安全
在Web应用开发中,安全是重中之重,尤其是PHP应用,由于其普及度高、入门门槛低,很多开发者在开发过程中容易忽视安全问题,导致应用出现安全漏洞,被黑客攻击,造成数据泄露、系统瘫痪等严重后果。
103 2
|
30天前
|
移动开发 缓存 定位技术
PHP在本地生活服务平台中的应用实战
随着本地生活服务行业的蓬勃发展,外卖、生鲜配送、家政服务、到店核销等场景的线上化需求日益迫切,而PHP凭借其开发高效、成本可控、生态完善的优势,成为本地生活服务平台开发的核心选择。
94 1