← 返回
AI智能

Amazon Scraper

High-performance containerized Amazon scraper (Docker + playwright-extra + Stealth plugin). Bypasses Amazon headless detection. Supports Amazon BSR, search r...
高性能容器化 Amazon 爬虫(Docker + playwright-extra + Stealth 插件),可绕过 Amazon 头检检测,支持 Amazon BSR、搜索结果等。
jiafar
AI智能 clawhub v3.4.1 3 版本 99479.8 Key: 无需
★ 6
Stars
📥 3,131
下载
💾 12
安装
3
版本
#latest

概述

Amazon Scraper

Docker容器化爬虫,基于 playwright-extra + Stealth 插件,专为绕过亚马逊反爬检测优化,同时支持通用动态网页爬取。

⚙️ 系统要求

  • Docker Engine 20.10+(必须已安装并运行)
  • 磁盘空间:~2GB(镜像 + Playwright 浏览器二进制文件)
  • 内存:建议 2GB+(Playwright 运行时需要)

快速开始

首次使用:在 skill 目录下执行一键构建脚本:

bash scripts/setup.sh

脚本会自动完成:构建 amazon-scraper 镜像 + 创建 ~/scrapes 输出目录。

模式选择规则

1. Amazon模式 (amazon_handler.js)

自动触发条件: URL包含 amazon.com,或用户提到亚马逊/Amazon/ASIN/BSR/选品/竞品/畅销榜/类目分析等关键词

根据URL自动识别页面类型:

URL特征页面类型可获取字段
---------
/gp/bestsellers/畅销榜rank, title, asin, price, rating, reviews, image, url
/zg/new-releases/新品榜同上
/zg/movers-and-shakers/飙升榜同上
/s?k=/s/搜索结果title, asin, price, rating, reviews, image, url, boughtPastMonth, sponsored
/dp//gp/product/产品详情title, asin, price, rating, reviews, brand, bsr, boughtPastMonth, dateFirstAvailable, category, bullets, details, image

⚠️ 重要规则:

  • Best Sellers页面没有月销量(boughtPastMonth)数据 — 亚马逊不在榜单页显示此信息
  • 要获取月销量,必须用搜索页(/s?k=关键词)或产品详情页(/dp/ASIN)
  • 如果用户同时需要排名+月销量,建议:先爬Best Sellers拿排名,再用搜索页补月销
  • BSR URL 必须使用 /gp/bestsellers//zgbs/ 会返回 Page Not Found
# 畅销榜(有排名,无月销)
docker run -t --rm amazon-scraper node assets/amazon_handler.js "https://www.amazon.com/gp/bestsellers/electronics"

# 搜索结果(有月销,无排名)
docker run -t --rm amazon-scraper node assets/amazon_handler.js "https://www.amazon.com/s?k=feather+duster"

# 产品详情(最全字段:BSR、品牌、卖点、月销)
docker run -t --rm amazon-scraper node assets/amazon_handler.js "https://www.amazon.com/dp/B001TQ6IHS"

# 多页爬取
docker run -t --rm amazon-scraper node assets/amazon_handler.js "URL" --pages 2

# 保存结果到文件
docker run -t --rm -v ~/scrapes:/data amazon-scraper node assets/amazon_handler.js "URL" --output result.json

# 用自己的代理覆盖内置配置
docker run -t --rm -e AMAZON_PROXIES="http://user:***@host:8001,..." amazon-scraper node assets/amazon_handler.js "URL"

输出格式: JSON

{
  "status": "SUCCESS",
  "type": "bestsellers|search|product-detail",
  "category": "品类名",
  "totalProducts": 30,
  "scrapedAt": "ISO时间",
  "products": [
    {
      "rank": 1,
      "title": "产品名",
      "asin": "B001TQ6IHS",
      "price": 9.94,
      "priceStr": "$9.94",
      "rating": 4.6,
      "reviews": 20547,
      "boughtPastMonth": "1K+",
      "image": "https://...",
      "url": "https://..."
    }
  ]
}

2. 通用模式 (main_handler.js)

触发条件: 非Amazon的URL,或用户提到爬取/抓取任意网页内容

  • 基于和 Amazon 模式相同的 playwright-extra + Stealth 架构
  • 内置代理已预配置,无需额外设置
  • 支持 --output 文件保存
  • 可通过环境变量覆盖内置代理
  • Playwright打开页面,等待JS加载完成
  • 提取 document.body.innerText(纯文本,去广告噪音)
  • 输出上限10000字符
  • 输出: {status:"SUCCESS", type:"GENERIC", title, data}
# 通用爬取(代理已内置)
docker run -t --rm amazon-scraper node assets/main_handler.js "https://任意网址"

# 保存文件
docker run -t --rm -v ~/scrapes:/data \
  amazon-scraper node assets/main_handler.js "https://任意网址" --output page.json

Agent调用决策树

用户给了URL?
├─ 包含 amazon.com → 用 amazon_handler.js
│   ├─ 需要月销量? → 建议用搜索URL(/s?k=) 或详情页(/dp/)
│   └─ 需要排名? → 用畅销榜URL(/gp/bestsellers/)
└─ 其他网站 → 用 main_handler.js (通用模式)

用户没给URL,只说了需求?
├─ "爬亚马逊XX品类Top" / "XX类目排行" / "XX畅销榜" → 构造 https://www.amazon.com/gp/bestsellers/品类
├─ "搜亚马逊XX" / "XX关键词搜索" / "找XX产品" → 构造 https://www.amazon.com/s?k=关键词
├─ "分析某个ASIN" / "看看这个产品" / "XX的详情" → 构造 https://www.amazon.com/dp/ASIN
├─ "XX的月销量" / "XX卖了多少" / "XX销量怎么样" → 用搜索页或详情页(有boughtPastMonth)
├─ "竞品分析" / "竞品调研" / "对手在卖什么" → 先搜索再逐个爬详情
├─ "选品" / "什么好卖" / "品类机会" / "市场调研" → Best Sellers + 搜索结合
└─ 其他网页 → 先web_search找到URL,再用通用模式爬

常见用户意图 → 操作映射

用户说操作
------
"帮我看看亚马逊XX品类"爬 /gp/bestsellers/品类 畅销榜
"XX在亚马逊卖得怎么样"搜索 /s?k=XX 看月销
"分析一下这个ASIN: BXXXXXXXXX"爬 /dp/ASIN 详情页
"XX品类有什么机会"畅销榜 + 搜索 综合分析
"帮我爬这个链接"判断URL类型,选对应handler
"帮我抓XX网站的内容"通用模式
"搜一下XX的竞品"搜索页爬取 + 分析
"XX月销多少" / "XX一个月卖多少"搜索页或详情页
"帮我看看top 100" / "热门产品"Best Sellers畅销榜
"新品有哪些" / "最近上了什么新品"/zg/new-releases/
"什么产品涨得快" / "飙升榜"/zg/movers-and-shakers/

代理配置

本 skill 已内置 5 个轮询代理,无需额外配置即可直接使用。

如需覆盖内置代理,可通过环境变量注入自己的代理:

变量用途格式
---------
AMAZON_PROXY单代理http://user:pass@host:port
AMAZON_PROXIES多代理轮询http://u:p@h1:8001,http://u:p@h2:8002,...
  • 轮询:多页爬取时每页自动切换下一个代理
  • 故障切换:单页失败时自动重试列表中下一个代理
  • 代理配置存放于 config/proxies.json,可直接修改文件更新代理列表

反爬能力

  • playwright-extra + puppeteer-extra-plugin-stealth — 自动修改 navigator、WebGL、Canvas 等 headless 特征
  • Chrome 123 UserAgent — 模拟真实 Mac Chrome 浏览器
  • 完整浏览器指纹 headers — Accept-Encoding: identity, Sec-Ch-Ua, Sec-Fetch-* 等
  • 1920x1080 viewport — 避免移动端/小屏检测
  • 自动滚动加载懒加载内容
  • Docker沙箱隔离,每次启动全新浏览器上下文
  • 代理轮询分散请求源 IP

局限

  • 通用模式输出上限10000字符
  • Amazon单页最多约30-50个产品
  • 不支持需要登录的页面
  • Docker容器启动有~15秒冷启动时间(含 stealth 插件初始化)

版本历史

共 3 个版本

  • v3.4.1 当前
    2026-04-30 08:54 安全 安全
  • v3.0.0
    2026-03-29 06:11 安全
  • v1.0.0
    2026-03-07 02:01

安全检测

腾讯云安全 (Keen)

安全,无风险
查看报告

腾讯云安全 (Sanbu)

安全,无风险
查看报告

🔗 相关推荐

ai-intelligence

self-improving agent

pskoett
捕获经验教训、错误和纠正,以实现持续改进。使用时机:(1)命令或操作意外失败;(2)用户纠正……
★ 4,056 📥 796,111
developer-tools

Horse Sticker Maker

jiafar
创建并部署一款喜庆的2026年马年春节动态GIF贴纸制作网页应用,用于生成自定义马年主题贴纸
★ 0 📥 1,177
ai-intelligence

ontology

oswalpalash
类型化知识图谱,用于结构化智能体记忆与可组合技能。支持创建/查询实体(人员、项目、任务、事件、文档)及关联...
★ 709 📥 243,539