Upwork Job Scraper | Scrape up to 10k Jobs โœจ (MCP) avatar

Upwork Job Scraper | Scrape up to 10k Jobs โœจ (MCP)

Pricing

from $1.50 / 1,000 job results

Go to Apify Store
Upwork Job Scraper | Scrape up to 10k Jobs โœจ (MCP)

Upwork Job Scraper | Scrape up to 10k Jobs โœจ (MCP)

Get ALL Upwork jobs instantly. Pre-indexed database delivers 10,000+ jobs at once. No cookies, no timeouts, filters that actually work. Perfect for freelancers, agencies, and Clay/Zapier automations. Pay only $0.003 per job - no subscriptions required. upwork@vistorio.online

Pricing

from $1.50 / 1,000 job results

Rating

4.8

(15)

Developer

Upwork Vibe

Upwork Vibe

Maintained by Community

Actor stats

38

Bookmarked

1.1K

Total users

254

Monthly active users

4.7 days

Issues response

2 days ago

Last modified

Share

Upwork Scraper - Extract up to 10,000 Jobs per request

Experience seamless Upwork job extraction with fast access to comprehensive job data. Pull up to 10,000 jobs from a single search without any authentication hassles.

โœจ Key Features

  • ๐Ÿ”‘ No Credentials Required: Simply configure your search parameters and start extracting. No cookies, login details, or complex authentication needed.
  • ๐Ÿ“ˆ High Volume Capacity: Extract up to 10,000 jobs per search - perfect for comprehensive market analysis and bulk data collection.
  • โšก Fast Data Access: Get results quickly from our pre-indexed database. Optimized for speed and reliability.
  • ๐ŸŽฏ Precision Filtering: 40+ filter parameters that work exactly as configured - budget, location, skills, client history, and more.
  • ๐Ÿ“Š Complete Job Data: Access all public job fields including budget details, client stats, vendor requirements, and application costs.

๐Ÿ› ๏ธ How It Works

  1. Configure Your Search: Set your desired filters - keywords, budget ranges, client requirements, experience levels
  2. Set Volume Limit: Choose how many jobs to extract (1 to 10,000)
  3. Run Extraction: Get results in clean, structured JSON format
  4. Export or Integrate: Use with Clay, Zapier, Make, or export to your preferred format

Input Sample

{
"limit": 200,
"fromDate": "2026-01-13",
"toDate": "2026-01-14",
"jobCategories": ["Web Development", "Mobile Development"],
"includeKeywords.keywords": ["React", "Node.js", "TypeScript"],
"includeKeywords.matchTitle": true,
"includeKeywords.matchSkills": true,
"includeKeywords.matchDescription": true,
"budget.hourlyRate.min": "40",
"client.includeLocations": [
{"type": "COUNTRY", "value": "US"},
{"type": "COUNTRY", "value": "CA"},
{"type": "COUNTRY", "value": "GB"},
{"type": "REGION", "value": "europe"}
],
"client.paymentMethodVerified": true
}

๐Ÿ’ฐ Pricing

EventPriceDescription
result-item$0.0035Per job from search results
result-item-from-ids$0.01Per job fetched by ID
client-details$0.003Addon: client work history & feedback
client-activity$0.003Addon: proposals, interviews, last activity
  • Pay only for what you use โ€” no subscriptions
  • Addon charges only apply when data is actually returned (no charge on empty results)
  • Platform costs included

๐Ÿ“Š See the Pricing tab for volume discounts (Bronze/Silver/Gold tiers).

๐Ÿ”Ž Fetch Jobs by ID

Skip the search โ€” fetch specific jobs directly by their Upwork job UID. When jobIds is provided, all search filters are ignored.

{
"limit": 10,
"jobIds": ["2036847678762808589", "2036802414567081499"]
}

Each job is charged as result-item-from-ids ($0.01). You can combine this with addons:

{
"limit": 10,
"jobIds": ["2036847678762808589"],
"addons.enableClientDetails": true,
"addons.enableClientActivity": true
}

๐Ÿ’Ž Premium Addons

Addons enrich each job result with additional data via per-job API calls.

Client Details Addon (addons.enableClientDetails)

  • Client work history and contractor feedback from previous freelancers
  • $0.003 per job (only charged when history data is returned)

Client Activity Addon (addons.enableClientActivity)

  • Number of proposals received
  • Last client activity timestamp
  • Candidates currently interviewing
  • Invites sent and unanswered invites
  • $0.003 per job (only charged when activity data is returned)

Job Attachments Addon (coming soon)

  • Job file attachments (PDFs, images, mockups) โ€” not yet available

Addons require additional API calls per job and will slow down processing โ€” consider extending your timeout window. We recommend testing your filters without addons first to verify result count.

๐Ÿ“– How to Use Upwork Job Scraper (Best practice)

Getting Started: Minimal Example

Start with this minimal configuration before adding filters:

{
"limit": 100
}

This returns the 100 most recent jobs across all categories. Once you see what data you're getting, you can add filters to narrow down the results to exactly what you need.

Daily Freelancer Monitor

{
"limit": 200,
"fromDate": "2025-01-13", // Yesterday
"toDate": "2025-01-14", // Today
"jobCategories": ["Web Development", "Mobile Development"],
"includeKeywords.keywords": ["React", "Node.js", "TypeScript"],
"includeKeywords.matchTitle": true,
"includeKeywords.matchSkills": false,
"includeKeywords.matchDescription": true,
"budget.hourlyRate.min": "40",
"client.includeLocations": [
{"type": "COUNTRY", "value": "US"},
{"type": "COUNTRY", "value": "CA"},
{"type": "COUNTRY", "value": "GB"}
],
"client.paymentMethodVerified": true
}

Agency Market Analysis

{
"limit": 5000,
"fromDate": "2025-01-01",
"toDate": "2025-01-14",
"jobCategories": ["Web Development", "Web & Mobile Design"],
"budget.fixedPrice.min": "5000",
"client.totalSpent.min": "10000",
"client.minFeedbackScore": "4.0",
"client.includeLocations": [
{"type": "REGION", "value": "north_america"},
{"type": "REGION", "value": "europe"}
],
"vendor.experienceLevel": ["INTERMEDIATE", "EXPERT"]
}

Clay Automation Daily Pull

{
"limit": 300,
"fromDate": "2025-01-13T00:00:00Z",
"toDate": "2025-01-13T23:59:59Z",
"includeKeywords.keywords": ["SaaS", "B2B", "startup"],
"includeKeywords.matchSkills": false,
"includeKeywords.matchTitle": false,
"includeKeywords.matchDescription": true,
"budget.minClientHireRate": 50,
"client.includeLocations": [
{"type": "REGION", "value": "europe"}
],
"client.paymentMethodVerified": true,
"client.totalSpent.min": "5000"
}

Advanced Filtering Example

{
"limit": 2000,
"fromDate": "2025-01-01T12:30:00Z",
"jobCategories": [
"Web Development",
"Web & Mobile Design"
],
"includeKeywords.keywords": ["React", "TypeScript", "Next.js"],
"includeKeywords.matchTitle": true,
"includeKeywords.matchDescription": true,
"includeKeywords.matchSkills": true,
"excludeKeywords.keywords": ["WordPress", "PHP", "Shopify"],
"excludeKeywords.matchTitle": true,
"excludeKeywords.matchDescription": true,
"excludeKeywords.matchSkills": true,
"budget.hourlyRate.min": "40",
"budget.hourlyRate.max": "150",
"budget.jobDurations": [
"UP_TO_THREE_MONTHS",
"UP_TO_SIX_MONTHS",
"MORE_THAN_SIX_MONTHS"
],
"budget.minClientHireRate": 50,
"client.paymentMethodVerified": true,
"client.minFeedbackScore": "4.0",
"client.includeLocations": [
{"type": "COUNTRY", "value": "US"},
{"type": "REGION", "value": "europe"},
{"type": "COUNTRY", "value": "GB"}
],
"client.totalSpent.min": "5000",
"vendor.experienceLevel": ["INTERMEDIATE", "EXPERT"],
"vendor.englishProficiency": "FLUENT"
}

๐Ÿ“Š Output format

Clean, structured JSON with all job details:

{
"uid": "1955020056847176693",
"title": "React Developer for SaaS Platform",
"description": "We are looking for an experienced React Developer to help us build and scale our SaaS platform for small-to-medium businesses. Youโ€™ll be working closely with our product and backend teams to deliver high-quality, performant, and maintainable features that enhance user experience and support rapid growth.",
"createdAt": "2025-01-15T10:30:00.000Z",
"skills": [
"React",
"TypeScript",
"Node.js",
"Redux",
"REST APIs"
],
"externalLink": "https://www.upwork.com/jobs/~021955020056847176693",
"applicationCost": 6,
"featured": false,
"category": "Web Development",
"ciphertext": "~021955020056847176693",
"questions": null,
"budget": {
"fixedBudget": 5000,
"hourlyRate": {
"min": 40,
"max": 80
}
},
"client": {
"timezone": "America/New_York",
"industry": "Technology",
"companySize": 10,
"countryCode": "US",
"phoneNumberVerified": true,
"paymentMethodVerified": true,
"enterprise": false,
"connectedAt": "2024-05-01T00:00:00.000Z",
"stats": {
"totalSpent": 125000,
"totalHires": 42,
"hireRate": 85,
"avgRate": 65,
"feedbackRate": 4.95,
"feedbackCount": 38
},
"history": [
{
"startDate": "2024-06-01",
"endDate": "2024-12-01",
"totalCharge": 15000,
"totalHours": 320,
"feedback": { "score": 5.0, "comment": "Excellent developer" }
}
]
},
"vendor": {
"hireType": "FREELANCER",
"countryCodes": ["US", "CA", "UK"],
"experienceLevel": "EXPERT",
"englishLevel": "FLUENT"
},
"activity": {
"totalApplicants": 12,
"totalHired": 0,
"totalInvitedToInterview": 3,
"unansweredInvites": 1,
"lastBuyerActivity": "2025-01-15T14:22:00.000Z"
},
"customJobScore": 4.8
}

๐Ÿ“ธ Output Sample

Output Sample

Field Descriptions

Core Fields:

  • uid: Unique identifier for the job
  • title: Job title/headline
  • description: Job description
  • createdAt: When the job was posted (ISO 8601)
  • externalLink: Direct link to job on Upwork
  • applicationCost: Connects required to apply
  • featured: Whether it's a featured/promoted job
  • category: Job category on Upwork
  • ciphertext: Encoded job reference
  • questions: Screening questions (array or null)
  • customJobScore: Client quality score (0-5) based on verification status, ratings, hire history, and spending patterns

Budget Object:

  • fixedBudget: Fixed price amount (0 if hourly)
  • hourlyRate.min/max: Hourly rate range (null if fixed)

Client Object:

  • timezone: Client's timezone (IANA format)
  • industry: Client's industry sector
  • companySize: Number of employees
  • countryCode: 2-letter country code
  • phoneNumberVerified: Phone verification status
  • paymentMethodVerified: Payment method verified
  • enterprise: Enterprise client flag
  • connectedAt: When joined Upwork
  • stats.totalSpent: Total spent on platform
  • stats.totalHires: Number of hires made
  • stats.hireRate: Percentage of jobs that result in hire
  • stats.avgRate: Average hourly rate paid
  • stats.feedbackRate: Average rating given (0-5)
  • stats.feedbackCount: Number of feedback entries
  • history: Client work history array (Client Details addon only)

Activity Object (Client Activity addon only):

  • totalApplicants: Number of proposals received
  • totalHired: Number of candidates hired
  • totalInvitedToInterview: Number invited to interview
  • unansweredInvites: Number of unanswered client invites
  • lastBuyerActivity: Timestamp of last client activity

Vendor Object:

  • hireType: "FREELANCER", "AGENCY", or "ANY"
  • countryCodes: Preferred freelancer locations
  • experienceLevel: "BEGINNER", "INTERMEDIATE", or "EXPERT"
  • englishLevel: "ANY", "BASIC", "CONVERSATIONAL", "FLUENT", or "NATIVE"

๐Ÿ“‹ Complete Input Parameters

โš™๏ธ Basic Settings

ParameterTypeDescriptionExample
limitintegerMax jobs to return (1-10000)1000
fromDatestringJobs posted after (YYYY-MM-DD or YYYY-MM-DDTHH:MM:SSZ)"2025-01-01" or "2025-01-01T00:00:00Z"
toDatestringJobs posted before (YYYY-MM-DD or YYYY-MM-DDTHH:MM:SSZ)"2025-12-31" or "2025-12-31T23:59:59Z"
jobCategoriesarrayUpwork category names["Web Development", "UI/UX Design"]
jobIdsarrayFetch specific jobs by UID (ignores all filters)["2036847678762808589"]

๐Ÿ’Ž Addons

ParameterTypeDescriptionPrice
addons.enableClientDetailsbooleanClient work history & feedback$0.003/job
addons.enableClientActivitybooleanProposals, interviews, last activity$0.003/job

๐Ÿ”Ž Keyword Filters

ParameterTypeDescriptionExample
includeKeywords.keywordsarrayMust contain these terms (auto-activates when set)["React", "Node.js"]
includeKeywords.matchTitlebooleanSearch in titlestrue
includeKeywords.matchDescriptionbooleanSearch in descriptionstrue
includeKeywords.matchSkillsbooleanSearch in required skillstrue
excludeKeywords.keywordsarrayExclude jobs with these terms (auto-activates when set)["WordPress", "PHP"]
excludeKeywords.matchTitlebooleanSearch in titlestrue
excludeKeywords.matchDescriptionbooleanSearch in descriptionstrue
excludeKeywords.matchSkillsbooleanSearch in required skillstrue

๐Ÿ’ฐ Budget & Payment

ParameterTypeDescriptionExample
budget.hourlyRate.minstringMinimum hourly rate (USD)"50"
budget.hourlyRate.maxstringMaximum hourly rate (USD)"150"
budget.fixedPrice.minstringMinimum fixed price (USD)"1000"
budget.fixedPrice.maxstringMaximum fixed price (USD)"10000"
budget.connectsPrice.minintegerMinimum connects required1
budget.connectsPrice.maxintegerMaximum connects required10
budget.jobDurationsarrayContract lengths["UP_TO_THREE_MONTHS"]
budget.hourlyWorkloadsarrayWeekly commitment["LESS_THAN_30_HOURS"]
budget.minClientHireRateintegerMin hire rate (%)50

๐Ÿข Client Requirements

ParameterTypeDescriptionExample
client.paymentMethodVerifiedbooleanVerified payment onlytrue
client.minFeedbackScorestringMin rating (0-5)"4.5"
client.totalSpent.minstringMinimum total spent (USD)"10000"
client.totalSpent.maxstringMaximum total spent (USD)"50000"
client.includeLocationsarrayClient locations[{"type": "COUNTRY", "value": "US"}]
client.excludeLocationsarrayExclude locations[{"type": "COUNTRY", "value": "PK"}]
client.companySizeRangearrayCompany sizes["UP_TO_100_EMPLOYEES"]

๐Ÿ‘ค Vendor Preferences

ParameterTypeDescriptionExample
vendor.experienceLevelarrayRequired experience["INTERMEDIATE", "EXPERT"]
vendor.englishProficiencystringEnglish level"FLUENT"
vendor.typearrayFreelancer/Agency["FREELANCER"]
vendor.includeLocationsarrayVendor locations[{"type": "COUNTRY", "value": "US"}]
vendor.includeFeaturedbooleanFeatured jobs onlytrue

Job Categories

Most Popular Categories:

  • "Web Development" - Frontend, backend, full-stack
  • "Mobile Development (Web/Mobile)" - Cross-platform mobile apps
  • "Mobile Development (IT)" - Native iOS/Android development
  • "UI/UX Design" - User interface and experience design
  • "AI/ML Engineering" - Machine learning and AI projects
  • "Data Science & Analytics" - Data analysis and visualization
  • "Digital Marketing" - SEO, PPC, social media
  • "Content Writing" - Articles, blogs, copywriting
  • "Ecommerce Development" - Online stores, Shopify
  • "DevOps Engineering" - CI/CD, cloud infrastructure

Development & Tech:

  • "Web Development"
  • "Mobile Development (Web/Mobile)"
  • "Mobile Development (IT)"
  • "Desktop Software Development"
  • "Ecommerce Development"
  • "Game Development"
  • "Game Design & Development"
  • "Blockchain & Cryptocurrency"
  • "AI/ML Engineering"
  • "Data Engineering"
  • "Cloud Computing"
  • "DevOps Engineering"
  • "DevOps & Solution Architecture"
  • "QA & Testing (Software)"
  • "QA & Testing (Web/Mobile)"

Design & Creative:

  • "UI/UX Design"
  • "Product Design"
  • "Visual Design"
  • "Illustration & Design"
  • "Web & Mobile Design"
  • "3D Modeling & CAD"
  • "Architecture & Interior Design"

Business & Admin:

  • "Product Management (Business)"
  • "Product Management (Tech)"
  • "Project Management"
  • "Business Analysis & Strategy"
  • "Virtual Assistance"
  • "Data Entry & Transcription"
  • "Market Research"

Marketing & Sales:

  • "Digital Marketing"
  • "Social Media Marketing"
  • "Content Writing"
  • "Brand Strategy & Marketing"
  • "Marketing Automation"
  • "Sales & Business Development"

Note: Use exact category names as shown (case-sensitive). Full list of 70+ categories available.

๐Ÿ”” Set Notifications

Notifications are ideal for real-time job monitoring when combined with scheduled runs. Get instant alerts for new opportunities directly to your preferred communication channel.

When to Use Notifications

  • Real-time monitoring: Get alerts as soon as matching jobs appear
  • Scheduled scraping: Receive job updates at regular intervals (every hour, daily, etc.)
  • Team collaboration: Share opportunities with your team via Discord/Slack
  • Personal alerts: Get notifications to your Telegram for urgent opportunities

Configuration Overview

Basic Settings

  • Notification Limit: 1-20 jobs per platform (default: 3)
  • Run Metadata: Optional summary message with run details and dataset URLs
  • Platform Support: Telegram, Discord, and Slack

Setting Up Telegram Notifications

Notificaiton example
  1. Create a Bot:

    • Message @BotFather on Telegram
    • Send /newbot and follow instructions
    • Save your bot token (e.g., 1234567890:ABCdefGHIjklMNOpqrsTUVwxyz)
  2. Get Your Chat ID:

    • Message @userinfobot to get your personal chat ID
    • For channels: Add bot as admin, channel ID starts with -100
  3. Configure in Actor:

{
"notifications.telegram.token": "YOUR_BOT_TOKEN",
"notifications.telegram.channelId": "YOUR_CHAT_ID",
"notifications.limit": 5,
"notifications.shouldSendRunMetadata": true
}

Setting Up Discord Notifications

Notificaiton example
  1. Create a Bot:

    • Go to Discord Developer Portal
    • Create new application โ†’ Bot โ†’ Copy token
    • Add bot to server with "Send Messages" permission
  2. Get Channel ID:

    • Enable Developer Mode in Discord settings
    • Right-click channel โ†’ Copy ID
  3. Configure in Actor:

{
"notifications.discord.token": "YOUR_BOT_TOKEN",
"notifications.discord.channelId": "CHANNEL_ID",
"notifications.limit": 10
}

Setting Up Slack Notifications

Notificaiton example
  1. Create Slack App:

    • Go to api.slack.com/apps
    • Create new app โ†’ OAuth & Permissions
    • Add scopes: chat:write and channels:read
    • Install to workspace โ†’ Copy bot token (starts with xoxb-)
  2. Add Bot to Channel:

    • Invite bot to your channel: /invite @your-bot-name
  3. Configure in Actor:

{
"notifications.slack.token": "xoxb-YOUR-TOKEN",
"notifications.slack.channelId": "CHANNEL_ID",
"notifications.limit": 5
}

Example: Real-Time Job Monitoring with Notifications

{
// Search parameters
"limit": 50,
"fromDate": "2025-01-14T12:00:00Z",
"toDate": "2025-01-14T14:00:00Z",
"jobCategories": ["Web Development"],
"includeKeywords.keywords": ["React", "urgent", "ASAP"],
"budget.hourlyRate.min": "75",
"client.paymentMethodVerified": true,
// Notification settings
"notifications.limit": 10, // Send up to 10 newest jobs
"notifications.shouldSendRunMetadata": true, // Include run summary
// Telegram configuration
"notifications.telegram.token": "YOUR_TOKEN",
"notifications.telegram.channelId": "YOUR_CHAT_ID",
// Discord configuration (optional - can use multiple platforms)
"notifications.discord.token": "YOUR_DISCORD_TOKEN",
"notifications.discord.channelId": "YOUR_DISCORD_CHANNEL"
}

Notification Features

  • Smart Filtering: Only the newest jobs matching your criteria are sent
  • Run Metadata: Optional summary with total results, dataset URLs, and run details
  • Multi-Platform: Send to multiple channels simultaneously
  • Limit Control: Prevent notification spam with configurable limits (1-20)
  • Schedule Compatible: Perfect for hourly/daily scheduled runs

Tips for Effective Notifications

  1. Use with Schedules: Set up hourly runs with 10-30 minute overlap for real-time monitoring
  2. Adjust Limits: Start with 3-5 notifications, increase if needed
  3. Multiple Channels: Use Telegram for personal alerts, Discord/Slack for team
  4. Filter Quality: Use strict filters to ensure only high-quality jobs trigger notifications
  5. Metadata Option: Enable for first few runs to verify configuration

๐Ÿ’ก Smart Usage Tips - Don't Pay Twice!

Live Job Monitoring (Near Real-Time)

โš ๏ธ Use 10-30 minute overlap ONLY when scraping up to the present moment

Jobs can take up to 30 minutes to sync to our database. If you're monitoring live jobs (toDate = now), use overlap to catch delayed jobs:

// First run at 9:00 AM (scraping up to NOW)
{
"limit": 50,
"fromDate": "2025-01-14T07:00:00Z",
"toDate": "2025-01-14T09:00:00Z" // NOW
}
// Next run at 11:00 AM (scraping up to NOW)
{
"limit": 50,
"fromDate": "2025-01-14T08:30:00Z", // 30-min overlap
"toDate": "2025-01-14T11:00:00Z" // NOW
}
// Next run at 1:00 PM (scraping up to NOW)
{
"limit": 50,
"fromDate": "2025-01-14T10:30:00Z", // 30-min overlap
"toDate": "2025-01-14T13:00:00Z" // NOW
}

When to use overlap: Only when your toDate is the current time (live monitoring) Overlap duration: 10-30 minutes maximum (30 min for maximum safety)

Historical Data Collection (Past Jobs)

โœ… NO overlap needed when scraping historical data

When collecting past jobs (not up to the present moment), use exact date boundaries:

// Day 1: Get January jobs
{
"limit": 1000,
"fromDate": "2025-01-01T00:00:00Z",
"toDate": "2025-01-31T23:59:59Z" // Past date - NO overlap needed
}
// Day 2: Get February jobs
{
"limit": 1000,
"fromDate": "2025-02-01T00:00:00Z", // Exact boundary - no overlap
"toDate": "2025-02-28T23:59:59Z" // Past date - NO overlap needed
}

Daily Batch Collection (Previous Day's Jobs)

โœ… NO overlap needed for daily historical pulls

// Monday: Get Sunday's jobs
{
"fromDate": "2025-01-13T00:00:00Z", // Sunday start
"toDate": "2025-01-13T23:59:59Z" // Sunday end - NO overlap
}
// Tuesday: Get Monday's jobs
{
"fromDate": "2025-01-14T00:00:00Z", // Monday start - exact boundary
"toDate": "2025-01-14T23:59:59Z" // Monday end - NO overlap
}

Key Rule: Overlap is ONLY for live monitoring when toDate = current time

Cost-Effective Filtering

Start with strict filters to minimize costs:

  • Use "client.paymentMethodVerified": true to filter serious clients
  • Set "budget.minClientHireRate": 50 to avoid job collectors
  • Add "client.totalSpent.min": "1000" for proven clients

๐Ÿ”ง Integration Options

Automation Platforms

  • Clay.com - Direct table import with enrichment
  • Make/Zapier - 5000+ app connections
  • n8n - Self-hosted workflows
  • API - REST API for custom integrations

Export Formats

  • JSON (default)
  • CSV
  • Direct to Google Sheets
  • Webhook delivery

๐Ÿ”„ n8n Integration Example

n8n is a powerful workflow automation tool that works perfectly with our Upwork Job Scraper. Here's a complete example workflow that scrapes jobs hourly and sends notifications to Slack.

Before pasting this into your workflow follow these instructions (you may need to ask your instance admin to do that):

  1. Open any workflow.
  2. Press Tab (or plus sign at top left on the screen).
  3. Type Apify
  4. Press install Apify community node.

n8n Workflow: easily expandable minimal example

Import this workflow JSON directly into n8n:

{
"nodes": [
{
"parameters": {
"rule": {
"interval": [
{
"field": "minutes"
}
]
}
},
"name": "Schedule Trigger",
"type": "n8n-nodes-base.scheduleTrigger",
"typeVersion": 1,
"position": [
-176,
-32
],
"id": "237b1913-b1db-48fe-84ac-71a066ee7685"
},
{
"parameters": {
"operation": "Run actor and get dataset",
"actorId": {
"__rl": true,
"value": "YdYsB7rsRY0EUb1lP",
"mode": "list",
"cachedResultName": "Upwork Job Scraper | Scrape up to 10k Jobs โœจ (upwork-vibe/upwork-job-scraper)",
"cachedResultUrl": "https://console.apify.com/actors/YdYsB7rsRY0EUb1lP/input"
},
"customBody": "={\n \"limit\": 100,\n \"fromDate\": \"{{ $now.minus(5, 'minutes').toUTC().toString() }}\",\n \"toDate\": \"{{ $now.toUTC().toString() }}\",\n \"jobCategories\": [\"Web Development\"]\n}"
},
"name": "Run Upwork Scraper",
"type": "@apify/n8n-nodes-apify.apify",
"typeVersion": 1,
"position": [
48,
-32
],
"id": "03ef964f-d758-436d-a47a-62b49168d9c3",
"credentials": {
"apifyApi": {
"id": "x5aAtsWTvkSeaXn9",
"name": "Apify account"
}
}
}
],
"connections": {
"Schedule Trigger": {
"main": [
[
{
"node": "Run Upwork Scraper",
"type": "main",
"index": 0
}
]
]
}
},
"pinData": {},
"meta": {
"templateCredsSetupCompleted": true,
"instanceId": "b1f96afe5804f8bb3692e38aeb44df7e1ef44f291dd2e3122a0e54fe737453c0"
}
}

๐Ÿ”„ Clay Integration Example

1. Set up an Apify task

  1. Create a task for this actor with your desired inputs.
  2. Run the task:
    • Verify that it returns the expected data.
    • Clay requires at least one successful run to use the task as a data source (it imports the latest run by default).
  3. (Optional) Create a schedule for the task to automate future runs.

2. Connect Apify to Clay

  1. Open Clay.
  2. Create a table:
  3. Go to Actions โ†’ Sources โ†’ View all sources (scroll to the bottom).
  4. Search for Apify and choose Import data from Apify actor.
  5. Select (or add) your Apify account.
  6. Choose the actor and the task you created in step 1.
  7. Configure data import:
    • You can pull results from a specific run, but
    • Itโ€™s recommended to let Clay fetch the latest runs, especially if you also created a schedule in step 1.3.
  8. Click Submit to finalize the integration.

You are now able to act on the received data as you please. Don't forget to also setup running the source on a schedule (separate from the Apify schedule but you should set up both for best results) to always have the latest data.

๐Ÿ“š API Documentation

Node.js

import { ApifyClient } from 'apify-client';
const client = new ApifyClient({ token: 'YOUR_API_TOKEN' });
const run = await client.actor('upwork-vibe/upwork-job-scraper').call(input);

Python

from apify_client import ApifyClient
client = ApifyClient('YOUR_API_TOKEN')
run = client.actor('upwork-vibe/upwork-job-scraper').call(input)

REST API

curl -X POST "https://api.apify.com/v2/acts/upwork-vibe~upwork-job-scraper/runs?token=YOUR_API_TOKEN" \
-H "Content-Type: application/json" \
-d '{
"limit": 100,
"includeKeywords.keywords": ["react", "javascript"],
"includeKeywords.matchSkills": false,
"includeKeywords.matchTitle": true,
"includeKeywords.matchDescription": true
}'

๐Ÿ“ Location Reference Guide

How to Use Locations

Locations in client.includeLocations, client.excludeLocations, and vendor.includeLocations use this format:

{"type": "COUNTRY", "value": "US"} // For countries
{"type": "REGION", "value": "europe"} // For regions

Common Country Codes (ISO 3166-1 alpha-2)

CountryCodeCountryCode
United StatesUSUnited KingdomGB
CanadaCAAustraliaAU
GermanyDEFranceFR
NetherlandsNLSwitzerlandCH
SwedenSEDenmarkDK
NorwayNOFinlandFI
SpainESItalyIT
PolandPLUkraineUA
IndiaINPakistanPK
BangladeshBDPhilippinesPH
SingaporeSGJapanJP
BrazilBRMexicoMX
ArgentinaARIsraelIL
United Arab EmiratesAESouth AfricaZA

Available Regions

RegionValueIncludes
North Americanorth_americaUS, CA, MX
EuropeeuropeAll EU countries + UK, CH, NO
AsiaasiaAll Asian countries
South Americasouth_americaAll South American countries
AfricaafricaAll African countries
OceaniaoceaniaAU, NZ, Pacific Islands

Example Usage

// Include only US and European clients
"client.includeLocations": [
{"type": "COUNTRY", "value": "US"},
{"type": "REGION", "value": "europe"}
]
// Exclude specific countries
"client.excludeLocations": [
{"type": "COUNTRY", "value": "PK"},
{"type": "COUNTRY", "value": "BD"},
{"type": "COUNTRY", "value": "IN"}
]
// Vendor location preferences
"vendor.includeLocations": [
{"type": "REGION", "value": "north_america"},
{"type": "COUNTRY", "value": "PH"}
]

Note: For the complete list of ISO country codes, see ISO 3166-1 alpha-2

๐Ÿ” Troubleshooting

Getting 0 Results?

  1. Check your date range - Ensure dates aren't in the future
  2. Verify category names - Must match exactly from the enum list (e.g., "Web Development" not "Web Dev")
  3. Remove filters progressively - Start broad, then add filters one by one
  4. Check parameter structure - Use dot notation format (e.g., "budget.hourlyRate.min": "50")

Validation Errors?

  1. Use dot notation - Not nested objects: "includeKeywords.matchTitle": true โœ… vs {"includeKeywords": {"matchTitle": true}} โŒ
  2. Exact category names - "Mobile Development (Web/Mobile)" not "Mobile Development"
  3. Location format - Must have both fields: {"type": "COUNTRY", "value": "US"}
  4. Quote string values - Budget amounts must be strings: "50" not 50

Performance Issues?

  1. Start small - Test with limit: 100 before scaling up
  2. Simplify filters - Complex keyword combinations slow processing
  3. Segment large requests - Use date ranges to break up big searches
  4. Avoid overlapping filters - Don't use contradictory include/exclude rules

Unexpected Costs?

  1. Always set limit - Without it, you might pull thousands of jobs
  2. Test first - Start with limit: 10 to verify your filters work
  3. Check itemCount - Monitor response counts before scaling up
  4. Remember billing - You pay $0.003 per job returned, not per API call

โœ๏ธ Support

โšก Feel free to reach out to the developer for any issues or suggestions for improvement.

๐Ÿ’ฌ ๐Ÿ“ง ๐Ÿ› ๐Ÿ’ก ๐Ÿš€