1688搜索商品列表API详解:关键词、价格区间与分页参数配置(附Python源码)

简介: 本文详解1688搜索商品列表API(alibaba.offer.search):支持关键词、类目ID、价格区间(单位为分!)、分页与排序参数配置,附可直接运行的Python封装代码,含MD5签名、自动翻页、避坑提示及生产级调用建议。(239字)

🔍 1688搜索商品列表API详解:关键词、价格区间与分页参数配置(附Python源码)

1688搜索商品列表API(alibaba.offer.search)是B2B选品、比价、铺货系统的入口接口。它的核心价值是让你用关键词+类目+价格筛选批量获取商品快照,再结合商品详情API完成全量同步。下面直接给你可落地的Python封装和参数解析。

一、 接口基本信息

项目 说明

接口名 alibaba.offer.search(也有文档称cn.alibaba.open.search.offer)

协议 HTTPS GET/POST

网关 https://gw.open.1688.com/openapi/param2/2/alibaba.offer.search/2.0

鉴权 AppKey + AppSecret(签名)+ AccessToken(买家身份可选,公开搜索可不传)

用途 关键词搜索、按类目过滤、价格区间筛选、分页遍历

⚠️ 避坑:搜索接口返回的是offer(供应信息)摘要,不含完整SKU。拿到offerId后需调alibaba.item.get获取详情。

二、 Python封装:搜索+分页遍历

ali1688_search.py

import hashlib
import time
import requests
import urllib.parse
from typing import List, Dict, Optional

封装好API供应商demo url=https://console.open.onebound.cn/console/?i=Lex 注册链接

class Ali1688SearchClient:
"""1688 商品搜索API客户端"""

def __init__(self, app_key: str, app_secret: str, access_token: str = None):
    self.app_key = app_key
    self.app_secret = app_secret
    self.access_token = access_token  # 公开搜索可不传,登录用户传session key
    self.gateway = "https://gw.open.1688.com/openapi/param2/2/alibaba.offer.search/2.0"

# ────────────────────────────────────────────
# 1688 标准 MD5 签名
# ────────────────────────────────────────────
def _sign(self, params: Dict) -> str:
    filtered = sorted((k, v) for k, v in params.items() if v is not None)
    qs = ''.join(f"{k}{v}" for k, v in filtered)
    raw = f"{self.app_secret}{qs}{self.app_secret}"
    return hashlib.md5(raw.encode('utf-8')).hexdigest().upper()

def _call(self, biz_params: Dict) -> Dict:
    """发起请求"""
    api_params = {
        "method": "alibaba.offer.search",
        "app_key": self.app_key,
        "timestamp": str(int(time.time() * 1000)),
        "format": "json",
        "v": "2.0",
        "sign_method": "md5",
    }
    if self.access_token:
        api_params["session"] = self.access_token

    # 业务参数做URL编码放入 param2
    api_params["param2"] = urllib.parse.quote_plus(
        str(biz_params).replace("'", '"')
    )
    api_params["sign"] = self._sign(api_params)

    resp = requests.get(self.gateway, params=api_params, timeout=15)
    resp.raise_for_status()
    data = resp.json()

    if "error_response" in data:
        err = data["error_response"]
        raise Exception(f"1688 Search Error [{err.get('code')}]: {err.get('msg')}")
    return data.get("alibaba_offer_search_response", {})

# ────────────────────────────────────────────
# 核心:搜索商品
# ────────────────────────────────────────────
def search_offers(self,
                  keyword: str,
                  price_start: Optional[float] = None,
                  price_end: Optional[float] = None,
                  category_id: Optional[int] = None,
                  page_no: int = 1,
                  page_size: int = 40) -> Dict:
    """
    Args:
        keyword:      搜索关键词,如 "纯棉T恤 男"
        price_start:  最低批发价(元)
        price_end:    最高批发价(元)
        category_id:  1688类目ID(可在后台查,或先调 offer.getCategory)
        page_no:      页码,从1开始
        page_size:    每页条数,最大50(推荐40)
    Returns:
        {offers: [...], totalResult: int, pageNo: int, pageSize: int}
    """
    biz = {
        "keywords": keyword,
        "pageNo": page_no,
        "pageSize": min(page_size, 50),   # 1688上限50
        "sortType": "booked",             # booked=成交量 desc, price_asc, price_desc, new
    }
    if price_start is not None:
        biz["beginPrice"] = str(int(price_start * 100))   # ⚠️ 单位是分!
    if price_end is not None:
        biz["endPrice"] = str(int(price_end * 100))
    if category_id:
        biz["categoryId"] = category_id

    return self._call(biz)

# ────────────────────────────────────────────
# 自动翻页遍历(生成器,避免内存爆炸)
# ────────────────────────────────────────────
def iter_all(self, keyword: str, max_pages: int = 5, **kwargs):
    """
    逐页yield每条offer,max_pages控制最大翻页数防死循环
    """
    for p in range(1, max_pages + 1):
        result = self.search_offers(keyword, page_no=p, **kwargs)
        offers = result.get("offers", []) or []
        total = result.get("totalResult", 0)

        if not offers:
            break

        for offer in offers:
            yield offer

        if p * kwargs.get("page_size", 40) >= total:
            break
        time.sleep(0.3)  # 友好限速

============================================================

使用示例

============================================================

if name == "main":
client = Ali1688SearchClient(
app_key="YOUR_APP_KEY",
app_secret="YOUR_APP_SECRET",
access_token=None # 公开搜索可不传
)

try:
    # ① 单次搜索
    result = client.search_offers(
        keyword="不锈钢保温杯 定制",
        price_start=15.0,     # ≥15元
        price_end=50.0,       # ≤50元
        page_no=1,
        page_size=20
    )

    offers = result.get("offers", [])
    total = result.get("totalResult", 0)
    print(f"✅ 共找到 {total} 个商品,当前页 {len(offers)} 条")

    for offer in offers[:3]:   # 预览前3条
        print(f"  • {offer.get('subject')}  "
              f"批发价:¥{offer.get('priceRange')}  "
              f"offerId:{offer.get('offerId')}")

    # ② 翻页遍历(取前2页)
    print("\n── 翻页遍历示例 ──")
    count = 0
    for offer in client.iter_all(
        keyword="不锈钢保温杯 定制",
        price_start=15.0,
        price_end=50.0,
        page_size=20,
        max_pages=2
    ):
        count += 1
        if count <= 3:
            print(f"  offerId:{offer.get('offerId')} {offer.get('subject')}")

except Exception as e:
    print(f"❌ 搜索失败: {e}")

三、 关键参数详解与避坑

  1. 价格区间单位 → 分(Cent)

这是最多人踩的坑!

✅ 正确:15~50元 → 传1500 和 5000

biz["beginPrice"] = "1500"
biz["endPrice"] = "5000"

❌ 错误:直接传 15.0 / 50.0 → 接口忽略或查无结果

  1. 分页限制

参数 说明 建议值

pageNo 从1开始 递增

pageSize 最大50,超量返回报错 20~40(平衡速度与完整性)

totalResult 返回值中带,用于判断终止 —

  1. 排序 sortType
    值 含义

booked 成交量↓(推荐选品用)

price_asc / price_desc 价格排序

new 上新时间↓

  1. 返回摘要字段(常用)
    字段 说明 下一步

offerId 供应ID 传 alibaba.item.get(offerId) 取详情

subject 商品标题 —

priceRange 起批价文本 仅展示,精确价格看详情

imageList[0] 主图URL —

minOrderQuantity 最小起订量(MOQ) ERP采购校验

supplierName 供应商店铺名 —

四、 生产级建议

  1. 关键词编码:中文关键词直接传UTF-8,requests会自动URL编码,无需手动处理。
  2. 类目约束:先通过alibaba.category.get拿到叶子类目ID再搜,可显著减少噪音(尤其服装/电子类)。
  3. 限流保护:搜索接口QPS通常≤10,建议sleep(0.2)或使用令牌桶控制。
  4. 增量更新:结合gmtModified筛选(部分搜索接口支持modifiedStartTime/End)做每日增量同步,不必全量翻页。

五、 完整对接链路(面试版)

关键词/类目


搜索API(alibaba.offer.search) ──▶ offerId列表
│ │
│ 详情API(alibaba.item.get)
│ ▼
│ SKU/批发价/库存 ──▶ ERP商品主数据


按totalResult翻页 ──▶ 去重(offerId已存在跳过) ──▶ 写ES/MySQL

需要我补充类目树获取API封装或商品详情API联动示例吗?可以直接说 👍

相关文章
|
17天前
|
人工智能 自然语言处理 文字识别
阿里云百炼Qwen3.7-Max简介:能力、优势、支持订阅计划参考
Qwen3.7-Max是阿里云百炼面向智能体时代推出的新一代旗舰模型,对标GPT-5.5、Claude Opus 4.7等闭源旗舰。该模型支持百万级token上下文窗口,具备顶级推理能力、多模态搜索与视觉理解增强、流式输出低延迟响应等核心优势,覆盖编程、办公、长周期自主执行等复杂场景。同时支持OpenAI接口兼容,便于系统快速迁移。用户可通过Token Plan团队或节省计划等订阅方式灵活调用,适合企业级高要求场景使用。
6182 30
阿里云百炼Qwen3.7-Max简介:能力、优势、支持订阅计划参考
|
2天前
|
数据采集 人工智能 前端开发
让 Coding Agent 从黑盒到透明:阿里云 Agent 观测审计数据采集实践
AI Agent 规模化落地带来执行黑盒、行为难追溯、成本难度量三大难题。阿里云基于 OTel 标准,面向 Coding Agent、个人通用助理和框架型 Agent,推出 LoongSuite Pilot、插件及探针等无侵入采集方案,让 Agent 实现可看见、可分析、可审计、可治理。
582 135
|
11天前
|
存储 定位技术 数据库
CodeGraph 如何让 Claude Code减少 7 成工具调用?
CodeGraph 为 Coding Agent 提供本地代码知识图谱,把函数、类、调用链和框架路由提前整理成“项目地图”,减少盲目搜索和文件读取。它不是新 Agent,而是上下文基础设施,让 Agent 更快找到正确代码路径,平均减少 7 成工具调用。
1219 3
|
9天前
|
人工智能 安全 定位技术
CodeGraph深度解析 让Claude Code工具调用直降七成的核心原理与实操教程
如今以Claude Code为代表的AI编程智能体已经成为开发者日常编码、项目重构、漏洞修复的必备工具。但在长期使用过程中,几乎所有开发者都会遇到同一个明显痛点:AI虽然具备强大的代码生成与分析能力,却常常陷入盲目探索的循环中。
1056 1
|
18天前
|
人工智能 自然语言处理 供应链
|
9天前
|
人工智能 弹性计算 安全
阿里云618活动时间、活动入口、优惠活动详细解读
2026年阿里云618创新加速季已全面开启,作为年度力度最大的云产品促销活动,本次大促覆盖轻量应用服务器、ECS云服务器、GPU云服务器、数据库、AI算力、安全服务、CDN等全品类产品,推出5亿元算力补贴、新用户限时秒杀、普惠满减、企业专享、免费试用、云大使返佣等多重福利,个人开发者、中小企业、AI团队均可享受专属低价。本文将系统梳理2026年阿里云618活动的完整时间节点、官方参与入口、各类优惠细则、使用规则、热门产品推荐及实操代码,帮助用户精准参与、高效省钱,以最低成本完成上云部署。
860 5
|
8天前
|
人工智能 自然语言处理 安全
Vibe Coding 实战:别盲目跟风,先分清 vibe coding 适合什么场景
本文系统总结vibe coding实战经验:明确其适用场景(原型、小工具、标准化模块),剖析5步落地流程(场景判定→结构化提示词→目录初始化→分模块生成→自动化校验),指出四大常见误区,并推荐适配工具Trae。强调“场景匹配+规则前置”是提效关键,避免盲目套用。
699 1