# RemoteOK Remote Job Listings Scraper \[🏷️ ON SALE 🎉] (`scrapers_lat/remoteok-scraper`) Actor

Extract remote job listings from RemoteOK worldwide. Scrape position, company, tags, location, apply URL, posting date and USD salary ranges when published.

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

## Pricing

from $8.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 -->
[![RemoteOK Remote Job Listings Scraper](https://scrapers.lat/banners/remoteok-scraper.png)](https://console.apify.com/actors/INWZ0Ty0algwSI9yJ/input)
<!-- /actor-banner -->

## RemoteOK Scraper

> Extract remote job listings from RemoteOK worldwide, with position, company, tags, location and published USD salary ranges

![Apify](https://img.shields.io/badge/Platform-Apify-1CE1CE?logo=apify&logoColor=white)
![Coverage](https://img.shields.io/badge/Coverage-Worldwide%20remote-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>14 fields</strong><br>per record</td>
<td align="center"><strong>Worldwide remote</strong><br>coverage</td>
<td align="center"><strong>JSON / CSV / Excel</strong><br>output formats</td>
</tr></table>

<br>

### What you get

Each record is one remote job from RemoteOK with its company, tags, location and salary range when published, ready for sourcing, market analysis or feeding a job board. Output fields:

- **position**: job title
- **company**: hiring company name
- **id**: RemoteOK job identifier
- **slug**: URL slug for the listing
- **url**: link to the public job posting
- **applyUrl**: link to apply for the role
- **location**: location text attached to the listing, such as a region or city
- **remote**: always true, every RemoteOK listing is a remote role
- **tags**: skill and category tags, for example engineer, react, golang, design or marketing
- **salaryMin**: lower bound of the published annual salary range in USD
- **salaryMax**: upper bound of the published annual salary range in USD
- **salaryText**: human-readable salary range string
- **postedAt**: when the job was posted
- **description**: full job description as clean text
- **rawDescription**: original job description with its HTML markup
- **observedAt**: when this listing was last seen by the scraper

### Who is it for

| Use case | Who benefits |
|---|---|
| Source remote engineering, design and marketing candidates | Recruiters and sourcers |
| Benchmark remote salary ranges by role and skill | Compensation and HR analysts |
| Track remote hiring demand by tag and category | Market researchers and analysts |
| Feed live remote jobs into a job board or aggregator | Product and data teams |
| Build a personal feed of new remote openings | Job seekers and career platforms |

### Frequently Asked Questions

**What jobs does RemoteOK cover?**
RemoteOK is a global board of fully remote roles across engineering, design, marketing, sales, customer support and more. Every listing is remote, with companies hiring from many countries, so the scraper returns worldwide remote openings rather than jobs tied to a single market.

**How many jobs can I collect in one run?**
You set the limit with Max Items. The scraper reads RemoteOK's full live feed and returns up to your chosen number of matching jobs, so you can pull a handful or the entire current feed of listings.

**Can I filter by keyword, tag or location?**
Yes. Use Search Terms to match the position, company or tags, add Tags to keep only jobs carrying specific tags such as react or golang, and set Location to keep jobs whose location text contains a place. You can also set a Minimum Salary to keep only jobs with a published salary at or above your threshold.

**Do the records include salary information?**
Yes, when the employer publishes it. RemoteOK shows salary ranges on a portion of its listings, returned as salaryMin, salaryMax and a readable salaryText in USD. Jobs without a published range leave those fields empty rather than guessing a value.

**Why is there no company logo field?**
RemoteOK's public feed does not expose company logo images, so the scraper does not include a logo field rather than ship an always-empty one. All other listing data, including company name, tags and salary, is returned in full.



<!-- 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:

- [RemoteOK Content Writer Jobs Scraper](https://apify.com/scrapers_lat/remoteok-scraper/examples/remoteok-content-writer-jobs): Scrape remote content writer jobs from RemoteOK. Get roles, companies, salaries, tags and apply URLs in JSON.
- [RemoteOK Customer Support Jobs Scraper](https://apify.com/scrapers_lat/remoteok-scraper/examples/remoteok-customer-support-jobs): Scrape remote customer support jobs from RemoteOK. Get roles, companies, salaries, tags and apply URLs in JSON.
- [RemoteOK DevOps Jobs Scraper](https://apify.com/scrapers_lat/remoteok-scraper/examples/remoteok-devops-jobs): Scrape remote DevOps jobs from RemoteOK. Extract titles, companies, salaries, tags and apply URLs in structured JSON.
- [RemoteOK Finance Jobs Scraper](https://apify.com/scrapers_lat/remoteok-scraper/examples/remoteok-finance-jobs): Scrape remote finance jobs from RemoteOK. Extract positions, companies, salaries, tags and apply links as clean JSON.
- [RemoteOK Python Developer Jobs Scraper](https://apify.com/scrapers_lat/remoteok-scraper/examples/remoteok-python-jobs): Scrape remote Python developer jobs from RemoteOK. Get roles, companies, salaries, tags and apply links in clean JSON.
- [RemoteOK Recruiter Jobs Scraper](https://apify.com/scrapers_lat/remoteok-scraper/examples/remoteok-recruiter-jobs): Scrape remote recruiter jobs from RemoteOK. Collect positions, companies, salaries, tags and apply links as clean JSON.
- [RemoteOK Sales Jobs Scraper](https://apify.com/scrapers_lat/remoteok-scraper/examples/remoteok-sales-jobs): Scrape remote sales jobs from RemoteOK. Collect positions, companies, salaries, tags and apply links as clean JSON.
- [RemoteOK Designer Jobs](https://apify.com/scrapers_lat/remoteok-scraper/examples/remoteok-designer-jobs): RemoteOK Designer Jobs
- [RemoteOK Engineer Jobs](https://apify.com/scrapers_lat/remoteok-scraper/examples/remoteok-engineer-jobs): RemoteOK Engineer Jobs
- [RemoteOK Marketing Jobs](https://apify.com/scrapers_lat/remoteok-scraper/examples/remoteok-marketing-jobs): RemoteOK Marketing Jobs

<!-- /example-tasks -->

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

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

- [LinkedIn Job Listings Scraper](https://apify.com/scrapers_lat/linkedin-jobs-scraper): Extract public LinkedIn job postings by keyword and location worldwide. Scrape job title, company...
- [Computrabajo Job Listings Scraper](https://apify.com/scrapers_lat/computrabajo-scraper): Extract job listings from Computrabajo across 19 LATAM countries. Scrape titles, companies...
- [Workable Job Listings Scraper](https://apify.com/scrapers_lat/workable-scraper): Extract public job listings from any Workable-hosted company careers board by account name or board...
- [Talent.com Job Listings Scraper](https://apify.com/scrapers_lat/talent-jobs-scraper): Extract public Talent.com job listings by keyword, location and country: title, company, salary...
- [GetOnBrd Tech Jobs & Salary Scraper](https://apify.com/scrapers_lat/getonbrd-scraper): Extract LATAM tech jobs and salary data from GetOnBrd. Scrape job title, company, category...
- [Dice Tech Job Listings Scraper](https://apify.com/scrapers_lat/dice-jobs-scraper): Extract public Dice.com tech job postings by keyword and location: title, company, location...

<!-- /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 RemoteOK. It only accesses data that is publicly available on the platform. Use it in accordance with RemoteOK's terms of service.

# Actor input Schema

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

Maximum number of remote job listings to collect. Optional.
## `searchTerms` (type: `array`):

Keywords to filter jobs by. A listing is kept when its position, company or tags match any of these terms (case-insensitive). Leave empty to collect every job in the feed.
## `tags` (type: `array`):

Keep only jobs carrying at least one of these RemoteOK tags (case-insensitive), for example engineer, react, golang, marketing, design, senior. Leave empty to ignore tag filtering.
## `location` (type: `string`):

Keep only jobs whose location text contains this value (case-insensitive), for example Europe, United States or Worldwide. Leave empty to ignore location filtering.
## `minSalary` (type: `integer`):

Keep only jobs whose published maximum salary is at or above this annual USD amount. Jobs without any published salary are excluded when this is set. Leave empty to ignore salary filtering.
## `proxyConfiguration` (type: `object`):

Optional Apify proxy. RemoteOK has no anti-bot protection and works fine from datacenter IPs, so a proxy is normally not needed.

## Actor input object example

```json
{
  "maxItems": 10,
  "searchTerms": [
    "engineer"
  ],
  "proxyConfiguration": {
    "useApifyProxy": false
  }
}
````

# 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,
    "searchTerms": [
        "engineer"
    ]
};

// Run the Actor and wait for it to finish
const run = await client.actor("scrapers_lat/remoteok-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,
    "searchTerms": ["engineer"],
}

# Run the Actor and wait for it to finish
run = client.actor("scrapers_lat/remoteok-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,
  "searchTerms": [
    "engineer"
  ]
}' |
apify call scrapers_lat/remoteok-scraper --silent --output-dataset

```

## MCP server setup

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

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "RemoteOK Remote Job Listings Scraper [🏷️ ON SALE 🎉]",
        "description": "Extract remote job listings from RemoteOK worldwide. Scrape position, company, tags, location, apply URL, posting date and USD salary ranges when published.",
        "version": "0.1",
        "x-build-id": "hLCCsQBeOqZp5WnCP"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/scrapers_lat~remoteok-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-scrapers_lat-remoteok-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~remoteok-scraper/runs": {
            "post": {
                "operationId": "runs-sync-scrapers_lat-remoteok-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~remoteok-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-scrapers_lat-remoteok-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": {
                    "maxItems": {
                        "title": "Max Items",
                        "minimum": 1,
                        "maximum": 1000000,
                        "type": "integer",
                        "description": "Maximum number of remote job listings to collect. Optional."
                    },
                    "searchTerms": {
                        "title": "Search Terms",
                        "type": "array",
                        "description": "Keywords to filter jobs by. A listing is kept when its position, company or tags match any of these terms (case-insensitive). Leave empty to collect every job in the feed.",
                        "items": {
                            "type": "string"
                        }
                    },
                    "tags": {
                        "title": "Tags",
                        "type": "array",
                        "description": "Keep only jobs carrying at least one of these RemoteOK tags (case-insensitive), for example engineer, react, golang, marketing, design, senior. Leave empty to ignore tag filtering.",
                        "items": {
                            "type": "string"
                        }
                    },
                    "location": {
                        "title": "Location",
                        "type": "string",
                        "description": "Keep only jobs whose location text contains this value (case-insensitive), for example Europe, United States or Worldwide. Leave empty to ignore location filtering."
                    },
                    "minSalary": {
                        "title": "Minimum Salary (USD)",
                        "minimum": 0,
                        "maximum": 100000000,
                        "type": "integer",
                        "description": "Keep only jobs whose published maximum salary is at or above this annual USD amount. Jobs without any published salary are excluded when this is set. Leave empty to ignore salary filtering."
                    },
                    "proxyConfiguration": {
                        "title": "Proxy Configuration",
                        "type": "object",
                        "description": "Optional Apify proxy. RemoteOK has no anti-bot protection and works fine from datacenter IPs, so a proxy is normally not needed.",
                        "default": {
                            "useApifyProxy": false
                        }
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
