eBay Product Scraper - Prices, Auctions & Buy It Now avatar

eBay Product Scraper - Prices, Auctions & Buy It Now

Pricing

from $3.00 / 1,000 product scrapeds

Go to Apify Store
eBay Product Scraper - Prices, Auctions & Buy It Now

eBay Product Scraper - Prices, Auctions & Buy It Now

Scrape active eBay listings across 13 markets: prices, shipping, sellers, auction bids, Buy It Now offers, fallback listing recovery, and diagnostics.

Pricing

from $3.00 / 1,000 product scrapeds

Rating

0.0

(0)

Developer

Nick

Nick

Maintained by Community

Actor stats

0

Bookmarked

106

Total users

21

Monthly active users

11 days ago

Last modified

Share

Use this eBay product scraper to extract active listings across 13 country markets, including prices, shipping, seller data, auction bids, Buy It Now listings, images, item IDs, and diagnostics.

Watchlist status - June 2026: eBay is currently returning HTTP 403 blocks from many Apify-hosted search and item-page requests. Active-listing mode now tries fallback listing recovery when eBay blocks access and is the primary working mode. Direct /itm/ URL and sold-listings modes are advanced JSON inputs because they depend on item/completed-sale pages being reachable; blocked runs return diagnostics instead of listing charges.

Best first run

{
"searchQuery": "sony wh-1000xm5",
"ebayDomain": "ebay.com",
"maxProducts": 25
}

Use this actor when you need an eBay product scraper, active listing monitor, auction intelligence feed, price-band dataset, or cross-market e-commerce monitor and you can tolerate eBay's current anti-bot variability. Start with an active keyword run; treat direct item URLs and soldOnly: true as advanced proxy-dependent JSON modes until your path proves it can reach item or completed-sale pages.

Related commerce workflows: use Shopify Scraper when you need reliable public storefront catalog exports and price-drop alerts, Amazon Scraper for ASIN and Best Sellers Rank tracking, and Bol.com Scraper for NL/BE marketplace monitoring.

No cookies, no OAuth, no API keys (for the scraping) - runs on public data only. AI keys are optional and only needed when enableAiAnalysis: true.

Scrape eBay product listings with prices, shipping, seller ratings, condition, and bid counts across all 13 eBay country domains. If active search pages are blocked, the actor attempts fallback listing recovery with a reduced but billable active-listing field set. Direct item URLs and sold-listings intelligence are advanced proxy-path-dependent JSON modes. Auction + Buy It Now + optional AI market analysis.

eBay Product Scraper

Search eBay by keyword to extract item IDs, titles, prices, shipping, seller names, feedback scores, condition, bids, time left, listing type, sold count, image URL, location, currency, and marketplace domain. Use it for resale research, competitor monitoring, auction tracking, marketplace pricing, and cross-border e-commerce analysis.

Sold Listings Mode Status

soldOnly: true is now an advanced JSON-only mode, hidden from the standard Console form because eBay currently blocks completed-sale pages on many Apify-hosted paths. Use the default active-listing mode for production runs. Only enable sold-listings mode after a tiny test proves your own proxy path can reach eBay completed-sale pages. Blocked sold-listings runs emit diagnostics and do not charge listing or summary events.

What It Does

eBay Scraper extracts structured product data from all 13 eBay country domains - US, UK, Germany, France, Italy, Spain, Australia, Canada, Netherlands, Austria, Switzerland, Ireland, and Poland. Provide a keyword and the actor returns 25+ fields per result: title, price, currency, shipping, condition, seller, feedback score, bid count, time left, listing type, sold count, and image URL. Advanced JSON inputs also exist for direct listing URLs and sold-listings tests when your proxy path supports them.

Operating modes:

1. Live-listings mode (default) - scrapes active auction and Buy It Now listings matching your keyword. This is the primary production path. Returns up to 100 results per run, sorted by best match, price, newly listed, or ending soonest. Supports price-range, condition, and listing-type filters. Charges $0.003 per listing.

2. Advanced direct item URL mode (productUrls, JSON input only) - accepts known /itm/ URLs and tries the primary eBay item page first, then fallback item recovery when eBay blocks the page. This mode is proxy-path dependent. Charges $0.003 only when a listing is recovered.

3. Advanced sold-listings mode (soldOnly=true, JSON input only) - switches to eBay's completed-sale filter (LH_Sold=1&LH_Complete=1, ~90-day window). This mode is currently proxy-path dependent and may return diagnostics when eBay blocks completed-sale pages. Charges apply only when sold rows or summaries are emitted.

AI analysis (enableAiAnalysis=true) - sends scraped listings to OpenRouter, Anthropic Claude, Google Gemini, OpenAI GPT, or self-hosted Ollama for a market overview, price-bracket analysis, seller-landscape summary, and buying recommendations. Charges $0.05 per analysis.

Runs use rendered-page extraction with polite 1-2.5 second delays and cross-page deduplication. Current eBay HTTP 403 blocks trigger active-listing fallback where possible, then diagnostics if no usable listing data can be recovered.

Supported eBay Domains:

DomainCountryCurrency
ebay.comUnited StatesUSD
ebay.co.ukUnited KingdomGBP
ebay.deGermanyEUR
ebay.frFranceEUR
ebay.itItalyEUR
ebay.esSpainEUR
ebay.com.auAustraliaAUD
ebay.caCanadaCAD
ebay.nlNetherlandsEUR
ebay.atAustriaEUR
ebay.chSwitzerlandCHF
ebay.ieIrelandEUR
ebay.plPolandPLN

Features

  • Active listing fallback recovery - active keyword runs try a fallback listing index when eBay returns HTTP 403
  • Advanced sold-listings mode (JSON-only watchlist) - completed-sale records and summaries when your proxy path can reach eBay completed-sale pages
  • 13 eBay country domains - US, UK, DE, FR, IT, ES, AU, CA, NL, AT, CH, IE, PL with automatic currency resolution
  • Auction + Buy It Now - both listing types in a single run, filter by either or scrape all
  • 25+ fields per listing - title, price, currency, MSRP/list_price, shipping, condition, seller, feedback score, bids, time-left, sold count, sold date, sponsored flag, best-offer flag, images, location
  • Detail-page enrichment (fetchDetails=true) - seller information, full item specifics, and complete description from individual listing pages
  • Flexible filtering - price range, item condition (new/used/refurbished/open box), listing type, sort order
  • 5 AI providers - OpenRouter (recommended, 300+ models), Anthropic Claude, Google Gemini, OpenAI GPT, Ollama (self-hosted)
  • Pay-per-event pricing - no subscription fees, pay only for what you scrape, with x402-ready PPE events for agent payments
  • Cross-page deduplication - maxProducts counts unique listings, not raw slots

Use Cases

  • Resellers & Arbitrage - monitor active prices, auction bids, and Buy It Now offers across multiple eBay domains.
  • Price Monitoring & Alerts - schedule daily active-listing runs to track asking-price changes for specific SKUs across marketplaces.
  • Market Research - analyze pricing distribution, seller landscape, and demand signals (bids, sold counts) for any product category. AI analysis adds structured price-bracket breakdowns and buying recommendations.
  • Competitive Intelligence - monitor competitor pricing and seller strategies across multiple regions. Track how prices differ between ebay.com, ebay.co.uk, and ebay.de for the same product.
  • Auction Intelligence - filter to auctions only, sort by ending soonest, and track bid counts and time-left for active listings. Identify underpriced auctions before they close.
  • E-commerce Sourcing - find wholesale or bulk deals by filtering to Buy It Now + free shipping + new condition. Use AI analysis to identify the best-value sellers.
  • Vintage & Collectibles Pricing - compare active asking prices and auction pressure; use sold-listings intelligence only after a small completed-sale test run succeeds on your proxy path.
  • Academic & Policy Research - export structured datasets for price-index research, consumer behavior studies, or e-commerce market analysis.

Input

Search Parameters

  • searchQuery - Keyword to search for on eBay (e.g., "laptop", "vintage Rolex", "pokemon cards"). Also accepts CLI aliases query, q, search, keyword, and searchTerm for compatibility with existing workflows.
  • productUrls - Hidden from the standard Console form. Advanced JSON-only list of direct eBay listing URLs (e.g., https://www.ebay.com/itm/123456789). Direct item pages and fallback item lookups are proxy-path dependent; use searchQuery for production runs.
  • ebayDomain - eBay country domain. Options: ebay.com (US, default), ebay.co.uk (UK), ebay.de (Germany), ebay.fr (France), ebay.it (Italy), ebay.es (Spain), ebay.com.au (Australia), ebay.ca (Canada), ebay.nl (Netherlands), ebay.at (Austria), ebay.ch (Switzerland), ebay.ie (Ireland), ebay.pl (Poland). Hidden API aliases domain and legacy ebaySite are also accepted.
  • listingType - Filter by listing format: all (default), auction, or buy_it_now.
  • sortBy - Sort results: best_match (default), price_low, price_high, ending_soonest, newly_listed.
  • itemCondition - Filter by condition: any (default), new, open_box, refurbished, used.
  • minPrice / maxPrice - Price range filter in the domain's local currency.
  • maxProducts - Maximum number of results per run (1-100, default 25). Advanced soldOnly=true is capped at 50 for bill safety.
  • fetchDetails - Visit each listing page for seller info, full description, and item specifics (slower, ~2-3x run time).

Advanced Sold-Listings Intelligence

  • soldOnly - Hidden from the standard Console form. Set true in JSON input only after a test proves completed-sale pages are reachable for your proxy path. Default: false.
  • soldDateLookback - Window in days for velocity calculation (30-365, default 90). eBay retains ~90 days of sold data.

AI Analysis

  • enableAiAnalysis - Enable AI market analysis. Default: false. Requires an API key for the selected provider.
  • llmProvider - AI backend: openrouter (default, cheapest), anthropic, google, openai, or ollama.
  • llmModel - Override the provider default model. Leave blank to use the recommended default.
  • openrouterApiKey - OpenRouter API key (openrouter.ai/keys).
  • anthropicApiKey - Anthropic API key (console.anthropic.com).
  • googleApiKey - Google AI API key (aistudio.google.com/app/apikey).
  • openaiApiKey - OpenAI API key (platform.openai.com/api-keys).
  • ollamaBaseUrl - Ollama base URL (default: http://localhost:11434). No API key needed for self-hosted.

Proxy Settings

  • proxyConfiguration - Apify Proxy settings. eBay currently blocks many Apify-hosted runs, including some residential exits. Active searches have fallback listing recovery, but sold-listings mode still needs eBay completed-sale pages to be reachable. If you bring a premium proxy, match its country to the selected eBay domain and validate with a tiny run before scaling.

Output

The default dataset contains buyer-facing listing, sold-summary, and optional AI-analysis records. Blocked or zero-result runs also emit one diagnostic_item: true sentinel in the default dataset so a successful run is never silently empty; the same operational context is written to a separate diagnostics dataset for support review.

Listing Item Fields

FieldDescription
itemIdeBay item ID (the numeric string from the /itm/ URL path)
titleProduct listing title
urlDirect link to the eBay listing
priceCurrent numeric price value
price_textPrice as displayed (e.g., "$29.99")
currencyISO 4217 currency code (e.g., USD, GBP, EUR)
list_priceStrikethrough / MSRP numeric price if discounted, else null
list_price_textStrikethrough price as displayed (e.g., "$299.99")
shipping_costShipping cost as float (0.0 = free, null = unknown)
shipping_textShipping info as displayed
free_shippingBool - true when shipping_cost == 0
conditionItem condition (New, Used, Refurbished, Open Box, etc.)
sellerCombined seller string, e.g. "logitech 99.6% positive (20.7K)"
seller_usernameBare seller username
seller_feedback_percentageSeller feedback percentage as float
seller_feedback_countFeedback count as integer (parsed from "(20.7K)" -> 20700)
bidsNumber of bids (auction items only)
end_timeAuction end date/time in ISO 8601 format (auction items only, else null)
time_leftTime remaining for auctions as human-readable text (e.g., "2d 4h")
sold_priceFinal sale price for completed auction listings in soldOnly mode (else null)
listing_typeauction, buy_it_now, or buy_it_now_or_best_offer
best_offerBool - true when seller accepts offers
is_sponsoredBool - true for promoted/sponsored listings
image_urlProduct image URL
sold_infoRaw sold/watching badge text (e.g., "184+ sold")
sold_countInteger parsed from sold_info ("2.1K+ sold" -> 2100)
sold_dateISO-8601 date when listing sold - populated only in soldOnly mode
sold_date_textRaw sold-date caption as displayed
is_soldBool - true for completed-sale listings
locationSeller location
domaineBay domain used for scraping
search_queryOriginal search term
scraped_atISO 8601 timestamp of extraction

Sample Listing Item

{
"itemId": "295854732101",
"title": "Pokemon TCG Scarlet & Violet Booster Box - 36 Packs - Sealed",
"url": "https://www.ebay.com/itm/295854732101",
"price": 129.99,
"price_text": "$129.99",
"currency": "USD",
"list_price": 159.99,
"list_price_text": "$159.99",
"shipping_cost": 0.0,
"shipping_text": "Free shipping",
"free_shipping": true,
"condition": "New",
"seller": "pokemon_central 99.8% positive (14.2K)",
"seller_username": "pokemon_central",
"seller_feedback_percentage": 99.8,
"seller_feedback_count": 14200,
"bids": null,
"end_time": null,
"time_left": null,
"sold_price": null,
"listing_type": "buy_it_now",
"best_offer": false,
"is_sponsored": false,
"image_url": "https://i.ebayimg.com/images/g/abc123/s-l1600.webp",
"sold_info": "184+ sold",
"sold_count": 184,
"location": "Los Angeles, CA",
"domain": "ebay.com",
"search_query": "pokemon cards",
"scraped_at": "2026-04-18T10:15:00Z"
}

Sold-Listings Summary Item

When soldOnly=true, each run also emits a single sold_listings_summary item:

{
"type": "sold_listings_summary",
"search_query": "pokemon booster box",
"domain": "ebay.com",
"lookback_days": 90,
"n_sold_listings": 100,
"currency": "USD",
"recommended_list_price": 129.95,
"median_price": 119.50,
"mean_price": 128.30,
"p10_p90_range": {"p10": 65.00, "p25": 89.99, "p75": 149.99, "p90": 199.00},
"price_range": {"min": 24.99, "max": 349.00},
"median_days_to_sell": 18,
"p90_days_to_sell": 62,
"market_velocity": "hot",
"confidence_score": 0.87,
"date_coverage_ratio": 0.92,
"sold_listings_trend": {
"has_history": true,
"price_delta_7d_pct": -2.1,
"price_delta_30d_pct": 5.4,
"volume_delta_pct": 12.0,
"velocity_delta": "steady -> hot",
"velocity_rank_delta": 1,
"direction": "up",
"sample_count_history": 14,
"previous_recommended_list_price": 124.50
},
"generated_at": "2026-04-22T23:00:00Z",
"methodology": "Sold-listings aggregation over eBay LH_Sold=1&LH_Complete=1 completed-sale filter"
}

Pricing

This actor is x402-ready because every chargeable unit is represented as a PPE event. It does not claim Skyfire-payable status because there is no $5+ Skyfire bundle event in this actor's pricing file.

EventPriceDescription
product-scraped$0.003Per live listing (auction or BIN) in default mode
sold-listing-scraped$0.005Per completed-sale listing in soldOnly mode
sold-summary-generated$0.05Once per run when the sold_listings_summary is emitted
sold-trend-detected$0.03Once per run when sold_listings_trend is populated from history (free on first run)
ai-analysis-completed$0.05Per AI market analysis report

Example costs: 50 live listings = $0.15. When completed-sale pages are reachable, 50 sold listings + summary (first run) = $0.30. Same with trend (subsequent runs) = $0.33. Diagnostic-only blocked runs do not charge listing or summary events.

vs. commercial alternatives: DataForSEO's eBay module charges $50+/mo and Terapeak is bundled with an eBay seller subscription at $7.99+/mo for sold-listing intelligence. This actor uses pay-per-event with no subscription: $0.003/listing and zero monthly fees.

Quick Start

Get your first eBay results in under a minute:

{
"searchQuery": "mechanical keyboard",
"maxProducts": 20,
"ebayDomain": "ebay.com"
}

Paste this into the Apify Console and hit Run. The actor returns up to 20 listings for the US marketplace.

Advanced sold-listings test (JSON input only):

{
"searchQuery": "pokemon booster box",
"ebayDomain": "ebay.com",
"soldOnly": true,
"maxProducts": 3,
"soldDateLookback": 90
}

Use this only after you have a proxy path that can reach eBay completed-sale pages. When reachable, it returns completed-sale records plus a sold_listings_summary; when blocked, it returns a diagnostic item instead.

Filtered auction search:

{
"searchQuery": "vintage Rolex watch",
"ebayDomain": "ebay.com",
"listingType": "auction",
"sortBy": "ending_soonest",
"minPrice": 500,
"maxPrice": 5000,
"maxProducts": 50
}

Used electronics on eBay UK:

{
"searchQuery": "MacBook Pro",
"ebayDomain": "ebay.co.uk",
"itemCondition": "used",
"sortBy": "price_low",
"maxProducts": 30
}

With AI market analysis:

{
"searchQuery": "Nintendo Switch OLED",
"maxProducts": 50,
"enableAiAnalysis": true,
"llmProvider": "openrouter",
"openrouterApiKey": "sk-or-..."
}

Advanced direct product URL test (JSON input only):

{
"productUrls": [
"https://www.ebay.com/itm/123456789",
"https://www.ebay.com/itm/987654321"
]
}

Proxy note: eBay is currently anti-bot sensitive from cloud and datacenter IPs. Start with maxProducts: 1-3, use a residential or premium proxy path, and match the exit country to the selected eBay domain before scaling.

MCP Quickstart - call this actor from Claude / Cursor / ChatGPT

Open Apify's hosted MCP server with this actor selected:

https://mcp.apify.com?tools=harvestlab/ebay-scraper

Then prompt the agent:

"Use the harvestlab/ebay-scraper actor on Apify to find active vintage Polaroid camera listings on ebay.co.uk with prices, shipping, seller fields, and item URLs. Push the results back as JSON."

Through Apify MCP, the agent can generate the right input, run the actor, and pipe the typed output back into your conversation.

Use with AI agents

ebay-scraper returns structured active-listing records with auction vs. Buy It Now status, bid count, seller feedback, currency, prices, and item URLs across 13 marketplaces. Use it as a single tool inside resale-arbitrage, price-discovery, or marketplace-monitoring workflows.

LangChain tool wrapper

from langchain_core.tools import Tool
from apify_client import ApifyClient
client = ApifyClient("YOUR_APIFY_TOKEN")
MARKET_DOMAINS = {
"us": "ebay.com",
"uk": "ebay.co.uk",
"de": "ebay.de",
"fr": "ebay.fr",
"it": "ebay.it",
"es": "ebay.es",
"nl": "ebay.nl",
"au": "ebay.com.au",
"ca": "ebay.ca",
"at": "ebay.at",
"ch": "ebay.ch",
"ie": "ebay.ie",
"pl": "ebay.pl",
}
def _track_ebay_active_listings(args: dict) -> list:
keyword = args["keywords"][0] if isinstance(args.get("keywords"), list) else args["keywords"]
marketplace = args.get("marketplace", "us").lower()
run = client.actor("harvestlab/ebay-scraper").call(run_input={
"searchQuery": keyword,
"ebayDomain": MARKET_DOMAINS.get(marketplace, "ebay.com"),
"maxProducts": args.get("maxProducts", 25),
"fetchDetails": args.get("fetchDetails", False),
})
return list(client.dataset(run["defaultDatasetId"]).iterate_items())
track_ebay_active_listings = Tool(
name="track_ebay_active_listings",
description="Scrape active eBay listings, prices, auction data, and seller fields across 13 marketplaces (US/UK/DE/FR/IT/ES/NL/AU/CA/AT/CH/IE/PL). Input: {keywords: [str] | str, marketplace: str, maxProducts: int}.",
func=_track_ebay_active_listings,
)
# track_ebay_active_listings.invoke({"keywords": ["vintage polaroid sx-70"], "marketplace": "us", "maxProducts": 25})

LangGraph resale-arbitrage node

from langgraph.graph import StateGraph, END
from typing import TypedDict
from statistics import median
from apify_client import ApifyClient
client = ApifyClient("YOUR_APIFY_TOKEN")
class ArbitrageState(TypedDict):
keyword: str
marketplaces: list[str]
spread_threshold_pct: float
medians: dict
arbitrage: bool
def arbitrage_node(state: ArbitrageState) -> ArbitrageState:
medians = {}
for mkt in state["marketplaces"]:
run = client.actor("harvestlab/ebay-scraper").call(run_input={
"searchQuery": state["keyword"], "ebayDomain": MARKET_DOMAINS.get(mkt, "ebay.com"), "maxProducts": 25,
})
prices = [i["price"] for i in client.dataset(run["defaultDatasetId"]).iterate_items() if i.get("price")]
if prices:
medians[mkt] = median(prices)
spread = (max(medians.values()) - min(medians.values())) / min(medians.values()) * 100 if medians else 0
return {**state, "medians": medians, "arbitrage": spread >= state["spread_threshold_pct"]}
graph = StateGraph(ArbitrageState)
graph.add_node("arbitrage", arbitrage_node)
graph.set_entry_point("arbitrage")
graph.add_edge("arbitrage", END)
# graph.compile().invoke({"keyword": "vintage polaroid sx-70", "marketplaces": ["com", "co.uk", "de"], "spread_threshold_pct": 25.0, "medians": {}, "arbitrage": False})

Troubleshooting

Getting blocked or seeing empty results eBay's bot-detection is currently blocking many Apify-hosted search and item-page requests with HTTP 403. Active-listing runs try a fallback public listing index after the primary eBay fetch fails; sold-listings mode cannot use that fallback because completed-sale history is not exposed there. Try a premium residential/mobile proxy path, match the proxy country to the eBay domain, and validate with maxProducts: 1-3 before scaling.

Blocked or zero-result runs also emit one diagnostic_item: true sentinel row in the default dataset, so a successful run is never silently empty. The sentinel is not billed as a product.

Prices appear in the wrong currency eBay localizes prices based on the requesting IP's country. If you see EUR prices when you expected USD (or vice versa), your proxy exit node is landing in the wrong country. Set proxyConfiguration.apifyProxyCountry to the two-letter country code that matches your target domain - for example US for ebay.com, GB for ebay.co.uk, DE for ebay.de. The scraper maps each of the 13 supported domains to its canonical country automatically when you use Apify Proxy without a country override.

Sold-listings results are empty or very sparse First, confirm soldOnly: true is set in your input - without it, the scraper runs in live-listing mode. Second, check whether the product has recent sold history: narrow or niche listings may have fewer than 5 completed sales in eBay's ~90-day window. Try broadening the search query. Third, ensure you are using the correct domain - a search on ebay.de for an English-language query will return far fewer sold listings than the same search on ebay.com.

Seller information missing on auction listings eBay does not render seller info in auction search result cards. Enable fetchDetails=true to fetch seller data from individual listing pages. This is slower (~2-3x run time) but provides complete seller information for all listing types.

AI analysis returns an error about a missing API key OpenRouter API key: set OPENROUTER_API_KEY env var OR openrouterApiKey input. Get one at openrouter.ai/keys. Anthropic: set ANTHROPIC_API_KEY env var OR anthropicApiKey input. Google AI: set GOOGLE_API_KEY env var OR googleApiKey input. OpenAI: set OPENAI_API_KEY env var OR openaiApiKey input. Ollama: ensure Ollama is running and accessible at the configured ollamaBaseUrl.

Cross-run trend block shows has_history: false This is normal on the first run for any (searchQuery, domain) pair. The first run seeds the history store; trend data (price_delta_7d_pct, velocity_delta, etc.) appears from the second run onward. The sold-trend-detected billing event ($0.03) fires only when history exists, so the first run is free on that dimension.

Maximum 100 products per run The actor caps results at 100 per search for PPE bill safety. For larger datasets, run the actor multiple times with different search queries or price-range filters to cover complementary market segments.


Scheduling and webhooks

Schedule daily price-watch runs in Apify Console to track eBay auction closing prices or BIN fluctuations for a target category. Wire a webhookUrl in n8n or Make to push deal alerts into a Slack channel or Telegram bot the moment a run finishes. Typical pipeline: "vintage Lego set 10179" daily eBay run -> n8n -> Slack alert when price drops below threshold.


This actor scrapes publicly available data from eBay. Users are responsible for:

  • Complying with eBay's Terms of Service
  • Adhering to applicable data protection laws (GDPR, CCPA, and local equivalents)
  • Using extracted data in accordance with all relevant regulations
  • Ensuring their use case does not violate any local or international laws

eBay scraping policy: eBay's User Agreement restricts automated access to its platform. Users are solely responsible for ensuring their use case complies with eBay's Terms of Service and any applicable API policies. This actor is provided as a technical tool; compliance obligations rest with the user.

GDPR and seller personal data: eBay seller profiles (username, feedback percentage, feedback count, location) constitute personal data under GDPR for EU-resident sellers. If you process data of individuals in the EU, you must have a lawful basis for processing, honor data-subject access and deletion requests, and avoid retaining seller personal data beyond your stated purpose.

Rate-limiting and crawl delay strategy: the actor inserts 1-2.5 second polite delays between page requests and applies exponential backoff on HTTP 429 (rate-limited) and 403 (access denied) responses. Backoff starts at 2 seconds and caps at 60 seconds with jitter. This keeps crawl rates within eBay's tolerance for public search traffic.

Data retention guidance: scrape outputs may include seller usernames, feedback scores, and item locations. Establish a retention policy aligned with your use case - for price-monitoring workloads a 90-day rolling window is typically sufficient. Delete or anonymize data no longer needed for your stated purpose.

For questions or concerns, please open an issue on the GitHub repository.

  • Amazon Scraper - pair eBay sold-comp data with Amazon catalog prices across 11 marketplaces for cross-platform arbitrage signals.
  • Product Hunt Scraper - surface early product trends on Product Hunt before they hit eBay reseller demand cycles.
  • Shopify Scraper - research the DTC store side of any product to understand brand pricing before reselling on eBay.