# eJobs Scraper - Romanian Job Listings (`studio-amba/ejobs-scraper`) Actor

Scrape job listings from eJobs.ro, Romania's largest job board with 100,000+ active postings. Search by keyword, location, and category. Extract job titles, companies, salaries, locations, descriptions, and employment types. No login or cookies required.

- **URL**: https://apify.com/studio-amba/ejobs-scraper.md
- **Developed by:** [Studio Amba](https://apify.com/studio-amba) (community)
- **Categories:** Jobs
- **Stats:** 2 total users, 1 monthly users, 100.0% runs succeeded, 0 bookmarks
- **User rating**: No ratings yet

## Pricing

Pay per usage

This Actor is paid per platform usage. The Actor is free to use, and you only pay for the Apify platform usage, which gets cheaper the higher subscription plan you have.

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

## 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

### What does eJobs Scraper do?

**eJobs Scraper** extracts job listings from [eJobs.ro](https://www.ejobs.ro), Romania's largest and most popular job board with over 100,000 active job postings. The scraper searches for jobs by keyword, location, and category, then returns structured data including job titles, companies, salaries, locations, descriptions, and employment types.

Run it on the Apify platform to get **API access, scheduling, proxy rotation, webhook integrations, and monitoring** out of the box. No login or cookies required -- all data is extracted from publicly available job listings.

### Why use eJobs Scraper?

- **Market research**: Analyze the Romanian job market by sector, salary ranges, and demand for specific skills across all industries.
- **Recruitment intelligence**: Monitor competitor hiring patterns across Romania's largest talent marketplace.
- **Salary benchmarking**: Collect salary data from thousands of Romanian job postings in RON and EUR.
- **Job aggregation**: Feed Romanian job listings into your own job board, aggregator platform, or HR dashboard.
- **Academic research**: Study employment trends, skill demand, and labor market dynamics in Romania and the EU.
- **Lead generation**: Identify actively hiring companies in Romania for B2B outreach and recruitment services.
- **Talent analytics**: Track which skills are in demand across Romanian cities and industries over time.

### How to scrape eJobs data

1. Go to the eJobs Scraper page on Apify Store.
2. Click **Try for free** to open the Actor in Apify Console.
3. Enter your search keyword (e.g. "programator", "developer", "inginer", or any Romanian job title).
4. Optionally set a location (Bucuresti, Cluj-Napoca, Timisoara, etc.) and job category.
5. Set the maximum number of results you want.
6. Click **Start** and wait for the run to finish.
7. Download your data as JSON, CSV, Excel, or connect it to your workflow via API.

That's it -- no coding required. The scraper handles pagination, proxy rotation, and data extraction automatically.

### Input

| Field | Type | Description | Default |
|-------|------|-------------|---------|
| `searchQuery` | String | Job search keyword (Romanian or English) | `programator` |
| `location` | String | City or region (Bucuresti, Cluj-Napoca, Timisoara, Iasi, etc.) | All Romania |
| `category` | String | Job category (IT, Finance, Marketing, Engineering, etc.) | All categories |
| `maxResults` | Integer | Maximum number of listings to scrape (1-10,000) | `100` |
| `includeDetails` | Boolean | Visit detail pages for full descriptions (slower) | `false` |
| `proxyConfiguration` | Object | Proxy settings (Romanian residential recommended) | Apify RO Residential |

#### Example input

```json
{
    "searchQuery": "programator",
    "location": "Bucuresti",
    "maxResults": 50,
    "proxyConfiguration": {
        "useApifyProxy": true,
        "apifyProxyGroups": ["RESIDENTIAL"],
        "apifyProxyCountry": "RO"
    }
}
````

### Output

The scraper outputs structured JSON data for each job listing. You can download the dataset in various formats such as JSON, HTML, CSV, or Excel.

#### Example output

```json
{
    "jobTitle": "Programator Java Senior",
    "company": "TechSoft Romania SRL",
    "location": "Bucuresti",
    "salary": "8000 - 14000 RON",
    "employmentType": "full-time",
    "category": "IT / Telecom",
    "postedDate": "05.06.2026",
    "jobDescription": "Cautam un programator Java cu experienta de minimum 5 ani pentru echipa noastra de dezvoltare...",
    "url": "https://www.ejobs.ro/locuri-de-munca/programator-java-senior/techsoft-romania/1234567",
    "sourceId": "1234567",
    "scrapedAt": "2026-06-09T12:00:00.000Z"
}
```

### Data fields

| Field | Description |
|-------|-------------|
| `jobTitle` | Job position title |
| `company` | Hiring company name |
| `location` | Job location (city or region in Romania) |
| `salary` | Salary range if displayed (RON or EUR) |
| `employmentType` | Employment type (full-time, part-time, remote, etc.) |
| `category` | Job category or industry sector |
| `postedDate` | Publication date of the listing |
| `jobDescription` | Description text (full with `includeDetails` enabled) |
| `url` | Direct link to the job listing on eJobs.ro |
| `sourceId` | eJobs.ro internal job ID |
| `scrapedAt` | ISO 8601 timestamp of data collection |

### How much does it cost to scrape eJobs.ro?

The eJobs Scraper uses Playwright with residential proxies for reliable data extraction. Typical costs:

- **100 listings** (search results only): ~$0.10-0.20 in platform credits
- **100 listings** (with full details): ~$0.30-0.50 in platform credits
- **1,000 listings** (search results only): ~$0.50-1.00 in platform credits

Costs depend on the number of pages loaded and proxy usage. Disabling `includeDetails` is faster and cheaper when you only need basic listing data.

### Tips and advanced options

- **Use Romanian keywords** for broader results. Many listings are in Romanian only (e.g. "programator" instead of "programmer", "inginer" instead of "engineer", "contabil" instead of "accountant").
- **Enable `includeDetails`** only when you need full job descriptions and requirements. It's 5-10x slower because it visits each job page individually.
- **Set `maxResults`** to control costs. Start small (10-50) to verify the output, then scale up.
- **Location filtering** supports all major Romanian cities: Bucuresti, Cluj-Napoca, Timisoara, Iasi, Constanta, Brasov, Craiova, Galati, Oradea, Ploiesti, Sibiu, Arad, and 15+ more. Use "Remote" for remote-only jobs.
- **Schedule runs** to track new job listings daily or weekly using Apify's built-in scheduler.
- **Combine with other scrapers** to build a comprehensive Romanian job market dataset. Check our BestJobs and LinkedIn scrapers for additional coverage.
- **Romanian proxy recommended**: Use Romanian residential proxies (`apifyProxyCountry: "RO"`) for the most reliable results and to avoid geo-blocking.

### Supported locations

Bucuresti (Bucharest), Cluj-Napoca, Timisoara, Iasi, Constanta, Brasov, Craiova, Galati, Oradea, Ploiesti, Sibiu, Arad, Pitesti, Bacau, Targu Mures, Buzau, Suceava, Botosani, Satu Mare, and Remote work.

### Supported categories

IT / Telecom, Finance / Accounting, Marketing, Engineering, Healthcare, Education / Training, Sales, Logistics / Distribution, Human Resources, Administrative, Construction, Legal, Production / Manufacturing, Retail, Tourism / Hotels / Restaurants, and Management.

### FAQ and support

#### Is it legal to scrape eJobs.ro?

This scraper extracts only publicly available job listing data that any visitor can see without logging in. It does not access private data, bypass authentication, or violate GDPR. Always review the website's Terms of Service before large-scale scraping and ensure your use case complies with applicable Romanian and EU laws.

#### The scraper returns 0 results

- Make sure your search query matches actual job listings on eJobs.ro. Try common Romanian job titles like "programator", "contabil", "inginer".
- Try broader search terms or remove location/category filters.
- Ensure residential proxies are enabled with Romania as the proxy country.
- The site may temporarily block automated access -- try again after a few minutes.

#### Can I get custom modifications?

Yes. If you need additional fields, different output formats, or integration with your systems, open an issue in the **Issues** tab or contact us for a custom solution.

#### How often should I run this scraper?

eJobs.ro updates listings continuously. For most use cases, running once daily or weekly is sufficient. Use Apify's scheduler to automate recurring runs.

# Actor input Schema

## `searchQuery` (type: `string`):

Job search keyword (e.g. 'programator', 'developer', 'inginer', 'marketing'). Supports Romanian and English. Defaults to 'programator' if empty.

## `location` (type: `string`):

City or region name (e.g. 'Bucuresti', 'Cluj-Napoca', 'Timisoara', 'Iasi'). Leave empty for all Romania.

## `category` (type: `string`):

Job category filter. Leave empty for all categories.

## `maxResults` (type: `integer`):

Maximum number of job listings to scrape.

## `includeDetails` (type: `boolean`):

Visit each job detail page to extract full description, requirements, and additional metadata. Slower but provides richer data.

## `proxyConfiguration` (type: `object`):

Proxy settings. Residential proxies recommended for reliable scraping.

## Actor input object example

```json
{
  "searchQuery": "programator",
  "category": "",
  "maxResults": 100,
  "includeDetails": false,
  "proxyConfiguration": {
    "useApifyProxy": true,
    "apifyProxyGroups": [
      "RESIDENTIAL"
    ],
    "apifyProxyCountry": "RO"
  }
}
```

# 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 = {
    "searchQuery": "programator",
    "proxyConfiguration": {
        "useApifyProxy": true,
        "apifyProxyGroups": [
            "RESIDENTIAL"
        ],
        "apifyProxyCountry": "RO"
    }
};

// Run the Actor and wait for it to finish
const run = await client.actor("studio-amba/ejobs-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 = {
    "searchQuery": "programator",
    "proxyConfiguration": {
        "useApifyProxy": True,
        "apifyProxyGroups": ["RESIDENTIAL"],
        "apifyProxyCountry": "RO",
    },
}

# Run the Actor and wait for it to finish
run = client.actor("studio-amba/ejobs-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 '{
  "searchQuery": "programator",
  "proxyConfiguration": {
    "useApifyProxy": true,
    "apifyProxyGroups": [
      "RESIDENTIAL"
    ],
    "apifyProxyCountry": "RO"
  }
}' |
apify call studio-amba/ejobs-scraper --silent --output-dataset

```

## MCP server setup

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

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "eJobs Scraper - Romanian Job Listings",
        "description": "Scrape job listings from eJobs.ro, Romania's largest job board with 100,000+ active postings. Search by keyword, location, and category. Extract job titles, companies, salaries, locations, descriptions, and employment types. No login or cookies required.",
        "version": "0.1",
        "x-build-id": "q0VYhbQlui3IOWiPT"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/studio-amba~ejobs-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-studio-amba-ejobs-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/studio-amba~ejobs-scraper/runs": {
            "post": {
                "operationId": "runs-sync-studio-amba-ejobs-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/studio-amba~ejobs-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-studio-amba-ejobs-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",
                "properties": {
                    "searchQuery": {
                        "title": "Search Query",
                        "type": "string",
                        "description": "Job search keyword (e.g. 'programator', 'developer', 'inginer', 'marketing'). Supports Romanian and English. Defaults to 'programator' if empty.",
                        "default": "programator"
                    },
                    "location": {
                        "title": "Location",
                        "type": "string",
                        "description": "City or region name (e.g. 'Bucuresti', 'Cluj-Napoca', 'Timisoara', 'Iasi'). Leave empty for all Romania."
                    },
                    "category": {
                        "title": "Category",
                        "enum": [
                            "",
                            "it",
                            "finance",
                            "marketing",
                            "engineering",
                            "healthcare",
                            "education",
                            "sales",
                            "logistics",
                            "hr",
                            "administration",
                            "construction",
                            "legal",
                            "production",
                            "retail",
                            "tourism",
                            "management"
                        ],
                        "type": "string",
                        "description": "Job category filter. Leave empty for all categories.",
                        "default": ""
                    },
                    "maxResults": {
                        "title": "Max Results",
                        "minimum": 1,
                        "maximum": 10000,
                        "type": "integer",
                        "description": "Maximum number of job listings to scrape.",
                        "default": 100
                    },
                    "includeDetails": {
                        "title": "Include Full Details",
                        "type": "boolean",
                        "description": "Visit each job detail page to extract full description, requirements, and additional metadata. Slower but provides richer data.",
                        "default": false
                    },
                    "proxyConfiguration": {
                        "title": "Proxy Configuration",
                        "type": "object",
                        "description": "Proxy settings. Residential proxies recommended for reliable scraping.",
                        "default": {
                            "useApifyProxy": true,
                            "apifyProxyGroups": [
                                "RESIDENTIAL"
                            ],
                            "apifyProxyCountry": "RO"
                        }
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
