Kijiji Scraper
Pricing
from $0.90 / 1,000 results
Kijiji Scraper
[๐ฐ $0.9 / 1K] Extract Canadian classified listings from Kijiji โ cars, real estate, jobs, electronics, services, and more. Paste search URLs or just type keywords and a location.
Pricing
from $0.90 / 1,000 results
Rating
0.0
(0)
Developer
SolidCode
Maintained by CommunityActor stats
0
Bookmarked
2
Total users
1
Monthly active users
4 days ago
Last modified
Categories
Share
Pull Canadian classified listings from Kijiji.ca at scale โ titles, CAD prices, city + address + latitude/longitude, seller names and masked phone numbers, image URLs, category-specific attributes, and posting dates for cars, real estate, electronics, jobs, services, pets, and every other Kijiji category. Built for Canadian retailers, automotive dealers, real estate agents, lead-generation agencies, and market researchers who need fresh Kijiji data without paging through the site one screen at a time.
Why This Scraper?
- All 13 Canadian provinces and territories โ search by city, postal code, or province, or set
location: "Canada"to sweep the whole country in one run. - Keyword search AND direct URL passthrough โ type a phrase like
"iPhone 15 Pro", or paste any Kijiji search, category, or pre-filtered URL exactly as it appears in your browser. URL filters (category, location, attributes) are honoured byte-for-byte. - 25+ structured fields per listing โ listing ID, title, CAD price, price type (fixed / negotiable / contact / free / swap / wanted), seller ID, address, latitude, longitude, neighbourhood intersection, all image URLs, category ID, and a flat
attributesarray of category-specific label/value pairs. - Optional deep-fetch mode โ toggle
fetchFullDetails: trueto enrich every row with view count, full HTML description, masked seller phone, seller website, dealer flag, listing status, and end date pulled from each ad's detail page. - Smart Canadian location resolver โ recognizes major cities ("Toronto", "Montreal, QC", "Calgary"), provinces ("Ontario", "BC"), postal codes ("M5V 2T6"), and free-text inputs. No need to look up Kijiji's internal location IDs.
- Five-way price filtering in CAD โ minimum price, maximum price, sort by newest / price low-to-high / price high-to-low, plus dropdown filters for ad type (Offering / Wanted) and seller type (Private / Business).
- Automatic deduplication across paginated Top Ads โ Kijiji repeats promoted listings on every page; the actor dedupes on listing ID so your dataset never carries the same ad twice.
- Actionable zero-result feedback โ when a query returns nothing, the run status echoes back the exact keywords, location, and filter combination that produced no hits so you know precisely what to broaden.
- Flat $0.90 per 1,000 results โ pay only for listings returned, no compute charges.
Use Cases
Price Monitoring & Competitive Intelligence
- Track competitor pricing across regional Kijiji markets
- Build CAD price histories on used-car models by trim and year
- Detect new listings within a price band the day they post
Lead Generation
- Build outreach lists with seller names, masked phone numbers, and websites
- Source private sellers vs. registered dealers with the Seller Type filter
- Capture every for-sale listing in a target city for sales pipelines
Inventory & Market Research
- Map automotive inventory by province for dealer network planning
- Track real-estate listing density and asking-rent shifts across Canadian cities
- Surface in-demand product categories by counting active listings
Trend Analysis
- Quantify Wanted-ad volume vs. Offering-ad volume to gauge demand
- Track average asking price by city and category over time
- Identify seasonal patterns in classified categories (bikes, snowmobiles, RVs)
Data Enrichment
- Enrich CRM records with current Kijiji listings tied to a seller name
- Pull image URLs to populate downstream catalog systems
- Feed marketplace dashboards with structured Canadian classifieds data
Getting Started
Simple Keyword Search
One topic, default location (all of Canada), 100 listings:
{"searchQueries": ["bikes"]}
Filtered Search with Location and Price Range
Newest Toyota Camry listings in the GTA between $5,000 and $15,000:
{"searchQueries": ["Toyota Camry"],"location": "Toronto, ON","minPrice": 5000,"maxPrice": 15000,"sortBy": "dateDesc","maxResults": 200}
URL Passthrough with Full Detail Enrichment
Paste a pre-filtered Kijiji URL (filters already encoded in the URL) and turn on detail mode to pull view counts, full descriptions, and seller contact info:
{"searchUrls": ["https://www.kijiji.ca/b-real-estate/city-of-toronto/c34l1700273?ad=offering"],"fetchFullDetails": true,"maxResults": 500}
Multi-Source Batch Run
Mix keyword searches and URLs in a single run โ results are combined and deduplicated:
{"searchQueries": ["iPhone 15 Pro", "MacBook Air M2"],"searchUrls": ["https://www.kijiji.ca/b-cars-vehicles/calgary/c27l1700199"],"location": "Canada","sellerType": "private","maxResults": 1000}
Input Reference
What to Scrape
| Parameter | Type | Default | Description |
|---|---|---|---|
searchUrls | string[] | ["https://www.kijiji.ca/b-cars-vehicles/canada/c27l0"] | One or more Kijiji search, category, or browse URLs. Paste exactly as copied from kijiji.ca โ URL filters are honoured. |
searchQueries | string[] | [] | Plain-text search terms (e.g. "iPhone 15 Pro"). Each query is combined with the Location field below. |
location | string | "Canada" | City ("Toronto, ON"), province ("Alberta"), or postal code ("M5V 2T6"). Use "Canada" to search nationwide. Only applies to keyword searches. |
Filters
Filters apply only to keyword searches โ URLs carry their own filters from the URL itself.
| Parameter | Type | Default | Description |
|---|---|---|---|
sortBy | select | Newest First | Sort order: Newest First, Price: Low to High, or Price: High to Low. |
minPrice | integer | none | Minimum price in CAD. Leave empty for no minimum. |
maxPrice | integer | none | Maximum price in CAD. Leave empty for no maximum. |
adType | select | Any | Ad type filter: Any, Offering (people selling), or Wanted (people buying). |
sellerType | select | Any | Seller filter: Any, Private (individual), or Business (registered dealer). Applies to listings that expose this attribute (most common on cars and electronics). |
Output Options
| Parameter | Type | Default | Description |
|---|---|---|---|
maxResults | integer | 100 | Maximum total listings to collect across all URLs and queries. Set to 0 for no limit. Start with 50โ100 to test. |
fetchFullDetails | boolean | false | When on, visits each listing's detail page to add view count, full HTML description, masked seller phone, seller website, dealer flag, status, and end date. Roughly doubles run cost. |
Output
Every row represents one Kijiji listing. Here's a typical result with full details enabled:
{"listingId": "1741234567","url": "https://www.kijiji.ca/v-cars-trucks/city-of-toronto/2019-toyota-camry-le/1741234567","title": "2019 Toyota Camry LE โ Low Km, Certified","description": "<p>Beautifully maintained 2019 Toyota Camry LE with only 48,000 km...</p>","price": 22500.00,"priceType": "negotiable","currency": "CAD","categoryId": "174","categoryName": "Cars & Trucks","adType": "offering","status": "active","postedAt": "2026-05-12T14:32:11Z","sortingDate": "2026-05-12T14:32:11Z","endDate": "2026-07-11T14:32:11Z","location": "Toronto (GTA)","locationId": "1700273","address": "Yonge & Eglinton, Toronto, ON","latitude": 43.7064,"longitude": -79.3982,"neighbourhood": "Yonge & Eglinton","sellerId": "u12345678","sellerName": "Maple Leaf Auto Sales","sellerType": "business","sellerPhone": "416-555-xxxx","sellerWebsite": "https://mapleleafautosales.ca","sellerRating": 4.7,"sellerVerified": true,"imageCount": 12,"imageUrls": ["https://i.kijiji.ca/abc.jpg", "https://i.kijiji.ca/def.jpg"],"views": 287,"adSource": "ORGANIC","attributes": [{ "label": "carmake", "value": "toyota" },{ "label": "carmodel", "value": "camry" },{ "label": "carbodytype", "value": "sedan" },{ "label": "numberofdoors", "value": "4" }],"flags": {"topAd": false,"highlight": false,"priceDrop": true,"isFromDealer": true,"showcase": false}}
Core Fields
| Field | Type | Description |
|---|---|---|
listingId | string | Unique Kijiji listing ID |
title | string | Listing title |
description | string | Listing description (truncated on search results; full HTML when fetchFullDetails: true) |
url | string | Direct Kijiji listing URL |
categoryId | string | Kijiji category ID |
categoryName | string | Human-readable category name (populated with fetchFullDetails) |
adType | string | offering (someone selling) or wanted (someone buying) |
postedAt | string | ISO-8601 timestamp the ad was posted |
sortingDate | string | ISO-8601 timestamp Kijiji uses for sort ranking |
Pricing
| Field | Type | Description |
|---|---|---|
price | number | Listing price in CAD (null when seller asks for contact-for-price) |
priceType | string | fixed, negotiable, contact, free, swap, or wanted |
currency | string | Always CAD |
Location
| Field | Type | Description |
|---|---|---|
location | string | City or region name as shown on Kijiji |
locationId | string | Kijiji internal location ID |
address | string | Street address when the seller chose to share their location (populated reliably with fetchFullDetails; often null on search results alone) |
latitude | number | Listing latitude |
longitude | number | Listing longitude |
neighbourhood | string | Nearest cross-streets (e.g. "Yonge & Bloor") |
Seller
| Field | Type | Description |
|---|---|---|
sellerId | string | Kijiji poster ID |
sellerName | string | Seller display name (populated with fetchFullDetails) |
sellerType | string | private or business when exposed by the listing |
sellerRating | number | Seller's Kijiji rating when available |
sellerVerified | boolean | Whether Kijiji marks this seller as verified |
sellerPhone | string | Masked phone number, last 4 digits as xxxx (populated with fetchFullDetails) |
sellerWebsite | string | Seller's website URL (populated with fetchFullDetails) |
Images, Attributes & Flags
| Field | Type | Description |
|---|---|---|
imageUrls | string[] | All listing image URLs (https-normalized) |
imageCount | number | Count of listing images |
attributes | object[] | Category-specific attributes as flat {label, value} pairs (e.g. carmake, carmodel, bedrooms, condition) |
flags | object | Listing flags: topAd, highlight, priceDrop, isFromDealer, showcase |
adSource | string | ORGANIC, TOP_AD, etc. |
virtualTourUrl | string | Virtual tour URL when present (real estate) |
youtubeVideoId | string | Embedded YouTube ID when the listing has a video |
Detail-Mode Fields
Populated only when fetchFullDetails: true.
| Field | Type | Description |
|---|---|---|
views | number | Total view count on the listing detail page |
status | string | Listing status (active, expired, removed, etc.) |
endDate | string | ISO-8601 timestamp the listing is scheduled to expire |
Tips for Best Results
- Paste pre-filtered URLs whenever possible. Apply your filters (category, location, attribute) directly on kijiji.ca, copy the URL, and drop it into
searchUrlsโ every URL parameter is respected exactly as the site interprets it. - Start small to test, then scale up. A
maxResults: 50first run takes under a minute and confirms the data matches your needs before you spend on a 10,000-listing pull. - Use
fetchFullDetails: trueonly for high-value lists. Detail mode adds one extra request per listing and roughly doubles run cost. Skip it for broad inventory sweeps; enable it for lead lists where you need seller phone, website, and view counts. - Combine keyword queries and URLs in one run. Mix
searchQuerieswithsearchUrlsto consolidate multiple monitoring sources into a single dataset and dedupe budget. - The Seller Type filter is best-effort. Kijiji exposes private vs. business on cars, electronics, and a few other categories; listings without this attribute pass through unfiltered so you don't end up with an empty dataset. Toggle
fetchFullDetails: truefor stricter seller-type enforcement. - For Wanted-ad research, use
adType: "wanted"on keyword searches. URL-based runs respect whatever?ad=parameter the URL already carries โ verify it's in the URL before relying on it. - Use city names over postal codes when you can. The location resolver knows every major Canadian city by name and maps postal-code prefixes to their nearest big city โ names are more predictable.
- The first few rows of any sorted run are promoted Top Ads. Kijiji's sort filters apply only to organic results โ the top of a
Price: Low to Highresponse will still show Top Ads at their original price. Filter byadSource: "ORGANIC"(or skipTOP_ADrows) if you want strictly sorted results.
Pricing
$0.90 per 1,000 results โ flat, competitive pricing for Canadian classifieds at scale. No compute charges โ you only pay per result returned.
| Results | Estimated Cost |
|---|---|
| 100 | $0.09 |
| 1,000 | $0.90 |
| 10,000 | $9.00 |
| 100,000 | $90.00 |
A "result" is any listing row in the output dataset. Platform fees (compute, storage) are additional and depend on your Apify plan.
Integrations
Export data in JSON, CSV, Excel, XML, or RSS. Connect to 1,500+ apps via:
- Zapier / Make / n8n โ Workflow automation
- Google Sheets โ Direct spreadsheet export
- Slack / Email โ Notifications on new results
- Webhooks โ Trigger custom APIs on run completion
- Apify API โ Full programmatic access
Legal & Ethical Use
This actor is designed for legitimate market research, competitive intelligence, lead generation, and inventory analysis on publicly accessible Kijiji listings. Users are responsible for complying with applicable Canadian laws (including PIPEDA), Kijiji's Terms of Service, and CASL for any subsequent outreach. Do not use extracted contact information for spam, harassment, or any unlawful purpose.