# OLX Brazil Classified Ads & Price Scraper (`scrapers_lat/olx-scraper`) Actor

Scrape OLX Brazil classified ads across every category and region. Extract title, price, currency, category, condition, location, seller name, attributes and images. Export to JSON, CSV or Excel. No login or API key.

- **URL**: https://apify.com/scrapers\_lat/olx-scraper.md
- **Developed by:** [Scrapers Lat](https://apify.com/scrapers_lat) (community)
- **Categories:** E-commerce, Automation, Developer tools
- **Stats:** 2 total users, 1 monthly users, 100.0% runs succeeded, 0 bookmarks
- **User rating**: No ratings yet

## Pricing

from $2.00 / 1,000 results

This Actor is paid per event. You are not charged for the Apify platform usage, but only a fixed price for specific events.
Since this Actor supports Apify Store discounts, the price gets lower the higher subscription plan you have.

Learn more: https://docs.apify.com/platform/actors/running/actors-in-store#pay-per-event

## What's an Apify Actor?

Actors are a software tools running on the Apify platform, for all kinds of web data extraction and automation use cases.
In Batch mode, an Actor accepts a well-defined JSON input, performs an action which can take anything from a few seconds to a few hours,
and optionally produces a well-defined JSON output, datasets with results, or files in key-value store.
In Standby mode, an Actor provides a web server which can be used as a website, API, or an MCP server.
Actors are written with capital "A".

## How to integrate an Actor?

If asked about integration, you help developers integrate Actors into their projects.
You adapt to their stack and deliver integrations that are safe, well-documented, and production-ready.
The best way to integrate Actors is as follows.

In JavaScript/TypeScript projects, use official [JavaScript/TypeScript client](https://docs.apify.com/api/client/js.md):

```bash
npm install apify-client
```

In Python projects, use official [Python client library](https://docs.apify.com/api/client/python.md):

```bash
pip install apify-client
```

In shell scripts, use [Apify CLI](https://docs.apify.com/cli/docs.md):

````bash
# MacOS / Linux
curl -fsSL https://apify.com/install-cli.sh | bash
# Windows
irm https://apify.com/install-cli.ps1 | iex
```bash

In AI frameworks, you might use the [Apify MCP server](https://docs.apify.com/platform/integrations/mcp.md).

If your project is in a different language, use the [REST API](https://docs.apify.com/api/v2.md).

For usage examples, see the [API](#api) section below.

For more details, see Apify documentation as [Markdown index](https://docs.apify.com/llms.txt) and [Markdown full-text](https://docs.apify.com/llms-full.txt).


# README

<!-- actor-banner -->
[![OLX Brazil Classified Ads & Price Scraper](https://scrapers.lat/banners/olx-scraper.png)](https://console.apify.com/actors/rq6OTJZLJYFmDPjYN/input)
<!-- /actor-banner -->

## OLX Brazil Classified Ads & Price Scraper

> Extract classifieds listings, prices, and seller data from OLX Brazil, the country's largest marketplace with over 600,000 ads in a single category search.

![Apify](https://img.shields.io/badge/Platform-Apify-1CE1CE?logo=apify&logoColor=white)
![Brazil](https://img.shields.io/badge/Coverage-Brazil-blue)
![Maintained](https://img.shields.io/badge/Maintained-Yes-brightgreen)
![Output](https://img.shields.io/badge/Output-JSON%20%7C%20CSV%20%7C%20Excel-orange)

<table><tr>
<td align="center"><strong>15 fields</strong><br>per record</td>
<td align="center"><strong>Brazil</strong><br>nationwide coverage</td>
<td align="center"><strong>JSON / CSV / Excel</strong><br>output formats</td>
</tr></table>

<br>

### What you get

Each listing returns a structured record ready to load into any database, spreadsheet, or analytics pipeline:

- **imageUrl**: main listing image
- **title**: full ad title as listed
- **price**: current asking price as a number
- **currency**: ISO currency code (BRL)
- **category**: OLX category name for the listing
- **condition**: item condition when published, such as new or used
- **location**: city and state of the listing
- **url**: direct link to the ad page
- **listingId**: unique OLX ad ID
- **publishedDate**: when the ad was published
- **description\***: full seller description
- **attributes\***: structured ad attributes such as brand, model, color and more
- **sellerName\***: display name of the seller
- **images\***: all images on the ad page
- **observedAt**: when this listing was last seen by the scraper

*\*These fields only appear when withDetails is set to true.*

### Who is it for

| Use case | Who benefits |
|---|---|
| Price monitoring | Resellers and retailers tracking second-hand prices in Brazil |
| Market research | Analysts studying consumer demand and pricing trends |
| Vehicle and electronics intelligence | Dealers benchmarking inventory and margins |
| Data pipelines | Developers feeding BI tools or recommendation engines |
| Lead generation | Sales teams sourcing sellers by category and region |

### Frequently Asked Questions

**Does it cover all of OLX Brazil?**  
Yes. The actor works across every OLX Brazil category and region, from cars and electronics to real estate and home goods. Paste any olx.com.br search or category URL and it collects the matching listings nationwide.

**How many results can I get per run?**  
There is no hard limit imposed by the actor. OLX returns 50 listings per page and a single category can hold hundreds of thousands of ads. For very large pulls, split by category, region, or search term to stay within practical page depth.

**Can I filter by category, location, condition, or keyword?**  
Yes. Apply any filters directly on olx.com.br and copy the resulting URL into the actor input. All filters encoded in the URL, including search keyword, category, region, and price range, are respected automatically.

**What extra data does the detail mode add?**  
When withDetails is enabled, the actor opens each ad page to add the full seller description, the complete image gallery, the seller name, and structured attributes like brand, model, and color. Leave it off for faster, lighter listing-only runs.

**What happens if an ad is removed or blocked during a run?**  
The actor skips unavailable ads without stopping the run and retries through fresh residential connections to clear access protection. Records that still fail will have the error field populated with the reason.



<!-- example-tasks -->
### Example use cases

Ready-to-run example tasks, each preconfigured for a common scenario. Open one and press run, or use it as a template:

- [OLX Brazil iPhone Listings and Prices Scraper](https://apify.com/scrapers_lat/olx-scraper/examples/olx-brazil-iphone-listings): Scrape iPhone listings from OLX Brazil with prices, condition, location and seller data for resale and price research.
- [OLX Brazil Used Cars Listings Scraper](https://apify.com/scrapers_lat/olx-scraper/examples/olx-brazil-used-cars-listings): Extract used car listings from OLX Brazil with make, model, price and location for dealers tracking the second hand market.
- [OLX Brazil Motorcycles Listings Scraper](https://apify.com/scrapers_lat/olx-scraper/examples/olx-brazil-motorcycles-listings): Collect motorcycle listings from OLX Brazil with price, brand and location for dealers and buyers comparing used bikes.
- [OLX Brazil Apartments for Rent Scraper](https://apify.com/scrapers_lat/olx-scraper/examples/olx-brazil-apartments-for-rent): Scrape apartments and property for rent on OLX Brazil with price, location and photos for renters and real estate analysts.
- [OLX Brazil Property for Sale Scraper](https://apify.com/scrapers_lat/olx-scraper/examples/olx-brazil-property-for-sale): Extract real estate for sale on OLX Brazil with asking price, location and details for investors and market research.
- [OLX Brazil PlayStation 5 Listings Scraper](https://apify.com/scrapers_lat/olx-scraper/examples/olx-brazil-playstation-5-listings): Track PlayStation 5 listings on OLX Brazil with prices, condition and seller data for resellers and price monitoring.
- [OLX Brazil Notebooks and Laptops Scraper](https://apify.com/scrapers_lat/olx-scraper/examples/olx-brazil-notebooks-laptops): Scrape notebook and laptop listings from OLX Brazil with price, condition and location for resale and price comparison.
- [OLX Brazil Used Furniture and Sofas Scraper](https://apify.com/scrapers_lat/olx-scraper/examples/olx-brazil-used-furniture-sofas): Collect used furniture and sofa listings from OLX Brazil with price, location and photos for resellers and shoppers.
- [OLX Brazil Local Services Listings Scraper](https://apify.com/scrapers_lat/olx-scraper/examples/olx-brazil-local-services-listings): Extract local services listings from OLX Brazil with provider, price and location for lead generation and market research.
- [OLX Brazil Job Listings Scraper](https://apify.com/scrapers_lat/olx-scraper/examples/olx-brazil-job-listings): Scrape job vacancies from OLX Brazil with title, location and details for recruiters and labor market analysis.

<!-- /example-tasks -->

<!-- x402 -->
### Export, API and AI agents (x402 + MCP)

Export the scraped data to **JSON, CSV or Excel**, pull it as a **dataset** through the Apify **API**, or wire it into your app with **no code**. This web scraper and data extractor also works for bulk data extraction and scheduled runs.

For AI agents: this Actor is available on **x402**, Apify's agentic payment standard built with Coinbase. An AI agent can discover, pay for and run it on its own with a funded wallet and a single HTTP request: no account, no subscription, no API key and no human in the loop. It also runs as an **MCP** tool inside Claude, Cursor and other AI clients out of the box. Learn more about [x402 agentic payments on Apify](https://docs.apify.com/platform/integrations/x402).
<!-- /x402 -->

<!-- related-actors -->
### Related scrapers

Need data from the same space? Here are other scrapers we build and maintain:

- [MercadoLibre Product Listings Scraper](https://apify.com/scrapers_lat/mercadolibre-scraper): Extract products, prices and seller data from MercadoLibre across 18 LATAM countries. Scrape...
- [Quince Product Scraper](https://apify.com/scrapers_lat/quince-scraper): Extract Quince.com products with prices, traditional retail price, discounts, variants, images and...
- [Rappi Restaurants & Stores Scraper](https://apify.com/scrapers_lat/rappi-scraper): Scrape restaurants and stores from Rappi Colombia! Extract store name, logo, category, rating...
- [Americanas Brazil Product Price Scraper](https://apify.com/scrapers_lat/americanas-scraper): Scrape product prices, installments, stock and marketplace sellers from Americanas Brazil. Search...
- [Chedraui Mexico Grocery Price Scraper](https://apify.com/scrapers_lat/chedraui-scraper): Scrape Chedraui Mexico product prices, EAN codes, stock, brands and installments by keyword or...
- [Cruz Verde Colombia Pharmacy Price Scraper](https://apify.com/scrapers_lat/cruz-verde-scraper): Extract drug prices, stock and laboratory data from Cruz Verde Colombia pharmacy.

<!-- /related-actors -->

<!-- scrapers-lat-cta -->
### More scrapers at scrapers.lat

This actor is built and maintained by [scrapers.lat](https://scrapers.lat), where we publish scrapers for Latin American and US public platforms: real estate, jobs, e-commerce, company registries and government data. Browse the full catalog, see live sample output for each one, or ask us for a custom scraper at [scrapers.lat](https://scrapers.lat).

---

> This actor is an independent tool and has no affiliation with OLX. It only accesses data that is publicly available on the platform. Use it in accordance with OLX's terms of service.

# Actor input Schema

## `maxItems` (type: `integer`):

Maximum number of listings to collect. Optional.
## `withDetails` (type: `boolean`):

When enabled, each listing's detail page is fetched to add description, full image gallery, seller name and item attributes.
## `startUrl` (type: `string`):

An OLX Brazil search or category URL. Apply any filters on olx.com.br and paste the resulting URL, for example https://www.olx.com.br/brasil?q=iphone or https://www.olx.com.br/autos-e-pecas/carros-vans-e-utilitarios
## `proxyConfiguration` (type: `object`):

Proxy settings. Residential proxies in Brazil are required to bypass OLX's Cloudflare protection.

## Actor input object example

```json
{
  "maxItems": 10,
  "withDetails": true,
  "startUrl": "https://www.olx.com.br/brasil?q=iphone",
  "proxyConfiguration": {
    "useApifyProxy": true,
    "apifyProxyGroups": [
      "RESIDENTIAL"
    ],
    "apifyProxyCountry": "BR"
  }
}
````

# Actor output Schema

## `results` (type: `string`):

No description

# API

You can run this Actor programmatically using our API. Below are code examples in JavaScript, Python, and CLI, as well as the OpenAPI specification and MCP server setup.

## JavaScript example

```javascript
import { ApifyClient } from 'apify-client';

// Initialize the ApifyClient with your Apify API token
// Replace the '<YOUR_API_TOKEN>' with your token
const client = new ApifyClient({
    token: '<YOUR_API_TOKEN>',
});

// Prepare Actor input
const input = {
    "maxItems": 10,
    "startUrl": "https://www.olx.com.br/brasil?q=iphone"
};

// Run the Actor and wait for it to finish
const run = await client.actor("scrapers_lat/olx-scraper").call(input);

// Fetch and print Actor results from the run's dataset (if any)
console.log('Results from dataset');
console.log(`💾 Check your data here: https://console.apify.com/storage/datasets/${run.defaultDatasetId}`);
const { items } = await client.dataset(run.defaultDatasetId).listItems();
items.forEach((item) => {
    console.dir(item);
});

// 📚 Want to learn more 📖? Go to → https://docs.apify.com/api/client/js/docs

```

## Python example

```python
from apify_client import ApifyClient

# Initialize the ApifyClient with your Apify API token
# Replace '<YOUR_API_TOKEN>' with your token.
client = ApifyClient("<YOUR_API_TOKEN>")

# Prepare the Actor input
run_input = {
    "maxItems": 10,
    "startUrl": "https://www.olx.com.br/brasil?q=iphone",
}

# Run the Actor and wait for it to finish
run = client.actor("scrapers_lat/olx-scraper").call(run_input=run_input)

# Fetch and print Actor results from the run's dataset (if there are any)
print("💾 Check your data here: https://console.apify.com/storage/datasets/" + run["defaultDatasetId"])
for item in client.dataset(run["defaultDatasetId"]).iterate_items():
    print(item)

# 📚 Want to learn more 📖? Go to → https://docs.apify.com/api/client/python/docs/quick-start

```

## CLI example

```bash
echo '{
  "maxItems": 10,
  "startUrl": "https://www.olx.com.br/brasil?q=iphone"
}' |
apify call scrapers_lat/olx-scraper --silent --output-dataset

```

## MCP server setup

```json
{
    "mcpServers": {
        "apify": {
            "command": "npx",
            "args": [
                "mcp-remote",
                "https://mcp.apify.com/?tools=scrapers_lat/olx-scraper",
                "--header",
                "Authorization: Bearer <YOUR_API_TOKEN>"
            ]
        }
    }
}

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "OLX Brazil Classified Ads & Price Scraper",
        "description": "Scrape OLX Brazil classified ads across every category and region. Extract title, price, currency, category, condition, location, seller name, attributes and images. Export to JSON, CSV or Excel. No login or API key.",
        "version": "0.1",
        "x-build-id": "hyLIymG1844NOueOy"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/scrapers_lat~olx-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-scrapers_lat-olx-scraper",
                "x-openai-isConsequential": false,
                "summary": "Executes an Actor, waits for its completion, and returns Actor's dataset items in response.",
                "tags": [
                    "Run Actor"
                ],
                "requestBody": {
                    "required": true,
                    "content": {
                        "application/json": {
                            "schema": {
                                "$ref": "#/components/schemas/inputSchema"
                            }
                        }
                    }
                },
                "parameters": [
                    {
                        "name": "token",
                        "in": "query",
                        "required": true,
                        "schema": {
                            "type": "string"
                        },
                        "description": "Enter your Apify token here"
                    }
                ],
                "responses": {
                    "200": {
                        "description": "OK"
                    }
                }
            }
        },
        "/acts/scrapers_lat~olx-scraper/runs": {
            "post": {
                "operationId": "runs-sync-scrapers_lat-olx-scraper",
                "x-openai-isConsequential": false,
                "summary": "Executes an Actor and returns information about the initiated run in response.",
                "tags": [
                    "Run Actor"
                ],
                "requestBody": {
                    "required": true,
                    "content": {
                        "application/json": {
                            "schema": {
                                "$ref": "#/components/schemas/inputSchema"
                            }
                        }
                    }
                },
                "parameters": [
                    {
                        "name": "token",
                        "in": "query",
                        "required": true,
                        "schema": {
                            "type": "string"
                        },
                        "description": "Enter your Apify token here"
                    }
                ],
                "responses": {
                    "200": {
                        "description": "OK",
                        "content": {
                            "application/json": {
                                "schema": {
                                    "$ref": "#/components/schemas/runsResponseSchema"
                                }
                            }
                        }
                    }
                }
            }
        },
        "/acts/scrapers_lat~olx-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-scrapers_lat-olx-scraper",
                "x-openai-isConsequential": false,
                "summary": "Executes an Actor, waits for completion, and returns the OUTPUT from Key-value store in response.",
                "tags": [
                    "Run Actor"
                ],
                "requestBody": {
                    "required": true,
                    "content": {
                        "application/json": {
                            "schema": {
                                "$ref": "#/components/schemas/inputSchema"
                            }
                        }
                    }
                },
                "parameters": [
                    {
                        "name": "token",
                        "in": "query",
                        "required": true,
                        "schema": {
                            "type": "string"
                        },
                        "description": "Enter your Apify token here"
                    }
                ],
                "responses": {
                    "200": {
                        "description": "OK"
                    }
                }
            }
        }
    },
    "components": {
        "schemas": {
            "inputSchema": {
                "type": "object",
                "required": [
                    "startUrl"
                ],
                "properties": {
                    "maxItems": {
                        "title": "Max Items",
                        "minimum": 1,
                        "maximum": 1000000,
                        "type": "integer",
                        "description": "Maximum number of listings to collect. Optional."
                    },
                    "withDetails": {
                        "title": "Scrape detail pages",
                        "type": "boolean",
                        "description": "When enabled, each listing's detail page is fetched to add description, full image gallery, seller name and item attributes.",
                        "default": true
                    },
                    "startUrl": {
                        "title": "Search URL",
                        "type": "string",
                        "description": "An OLX Brazil search or category URL. Apply any filters on olx.com.br and paste the resulting URL, for example https://www.olx.com.br/brasil?q=iphone or https://www.olx.com.br/autos-e-pecas/carros-vans-e-utilitarios"
                    },
                    "proxyConfiguration": {
                        "title": "Proxy configuration",
                        "type": "object",
                        "description": "Proxy settings. Residential proxies in Brazil are required to bypass OLX's Cloudflare protection.",
                        "default": {
                            "useApifyProxy": true,
                            "apifyProxyGroups": [
                                "RESIDENTIAL"
                            ],
                            "apifyProxyCountry": "BR"
                        }
                    }
                }
            },
            "runsResponseSchema": {
                "type": "object",
                "properties": {
                    "data": {
                        "type": "object",
                        "properties": {
                            "id": {
                                "type": "string"
                            },
                            "actId": {
                                "type": "string"
                            },
                            "userId": {
                                "type": "string"
                            },
                            "startedAt": {
                                "type": "string",
                                "format": "date-time",
                                "example": "2025-01-08T00:00:00.000Z"
                            },
                            "finishedAt": {
                                "type": "string",
                                "format": "date-time",
                                "example": "2025-01-08T00:00:00.000Z"
                            },
                            "status": {
                                "type": "string",
                                "example": "READY"
                            },
                            "meta": {
                                "type": "object",
                                "properties": {
                                    "origin": {
                                        "type": "string",
                                        "example": "API"
                                    },
                                    "userAgent": {
                                        "type": "string"
                                    }
                                }
                            },
                            "stats": {
                                "type": "object",
                                "properties": {
                                    "inputBodyLen": {
                                        "type": "integer",
                                        "example": 2000
                                    },
                                    "rebootCount": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "restartCount": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "resurrectCount": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "computeUnits": {
                                        "type": "integer",
                                        "example": 0
                                    }
                                }
                            },
                            "options": {
                                "type": "object",
                                "properties": {
                                    "build": {
                                        "type": "string",
                                        "example": "latest"
                                    },
                                    "timeoutSecs": {
                                        "type": "integer",
                                        "example": 300
                                    },
                                    "memoryMbytes": {
                                        "type": "integer",
                                        "example": 1024
                                    },
                                    "diskMbytes": {
                                        "type": "integer",
                                        "example": 2048
                                    }
                                }
                            },
                            "buildId": {
                                "type": "string"
                            },
                            "defaultKeyValueStoreId": {
                                "type": "string"
                            },
                            "defaultDatasetId": {
                                "type": "string"
                            },
                            "defaultRequestQueueId": {
                                "type": "string"
                            },
                            "buildNumber": {
                                "type": "string",
                                "example": "1.0.0"
                            },
                            "containerUrl": {
                                "type": "string"
                            },
                            "usage": {
                                "type": "object",
                                "properties": {
                                    "ACTOR_COMPUTE_UNITS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_WRITES": {
                                        "type": "integer",
                                        "example": 1
                                    },
                                    "KEY_VALUE_STORE_LISTS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_INTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_EXTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_RESIDENTIAL_TRANSFER_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_SERPS": {
                                        "type": "integer",
                                        "example": 0
                                    }
                                }
                            },
                            "usageTotalUsd": {
                                "type": "number",
                                "example": 0.00005
                            },
                            "usageUsd": {
                                "type": "object",
                                "properties": {
                                    "ACTOR_COMPUTE_UNITS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_WRITES": {
                                        "type": "number",
                                        "example": 0.00005
                                    },
                                    "KEY_VALUE_STORE_LISTS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_INTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_EXTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_RESIDENTIAL_TRANSFER_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_SERPS": {
                                        "type": "integer",
                                        "example": 0
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
