JobToday Scraper avatar

JobToday Scraper

Pricing

from $1.00 / 1,000 results

Go to Apify Store
JobToday Scraper

JobToday Scraper

Scrape job listings from JobToday across UK, Spain, France, USA and Italy. Extract salaries, GPS coordinates, company info, employment type and full descriptions. Keyword, location and easy-apply filters included.

Pricing

from $1.00 / 1,000 results

Rating

0.0

(0)

Developer

Unfenced Group

Unfenced Group

Maintained by Community

Actor stats

1

Bookmarked

2

Total users

1

Monthly active users

10 days ago

Last modified

Share

JobToday Scraper

Scrape structured job listings from JobToday — Global (Hourly). 200,000+ active listings. No API key required.


Why this scraper?

⏱️ Hourly and shift work — instant hiring

JobToday specialises in hospitality, retail, and service sector roles with fast hiring cycles. Strong in UK, US, and European markets.

📄 Full job descriptions

Enable fetchDetails to retrieve complete job descriptions in all three formats.

💰 Hourly rate extraction

Hourly rates parsed into salaryMin, salaryMax with salaryPeriod: HOUR.

🔄 Repost detection

Cross-run deduplication with a 90-day TTL. Use skipReposts: true for new-only feeds.

🔗 Direct URL scraping

Supply specific JobToday search or category URLs via startUrls.

⚙️ No API key required

Runs without any third-party credentials.


Input parameters

ParameterTypeDescriptionDefault
maxItemsintegerMaximum number of results to return.5
skipRepostsbooleanSkip listings already seen in previous runs (90-day deduplication window).false

Output schema

Each result contains the following fields.

FieldTypeDescription
idstringUnique job listing ID from the source platform.
urlstringDirect URL to the job listing.
titlestringJob title as published.
companystringEmployer / company name.
locationstringFull location string as published.
citystringCity of the work location.
countrystringCountry code (ISO 3166-1 alpha-2).
contractTypestringContract type (permanent, contract, temporary, etc.).
workSchedulestringWork schedule (full-time, part-time, etc.).
salaryMinnumberMinimum salary (null if not published by employer).
salaryMaxnumberMaximum salary (null if not published by employer).
salaryCurrencystringISO 4217 currency code (null if no salary published).
salaryPeriodstringSalary period: YEAR / MONTH / WEEK / DAY / HOUR.
publishDatestringPublication date (YYYY-MM-DD).
publishDateISOstringPublication date in ISO 8601 format.
sourcestringSource domain name.
scrapedAtstringISO 8601 timestamp of when this item was scraped.
contentHashstringMD5 hash of key fields for change detection (16 chars).
summarystringHuman-readable one-line summary of the listing.
changeStatusstringChange status: NEW / MODIFIED / UNCHANGED.
isRepostbooleanTrue if this listing was seen in a previous run (90-day window).
originalPublishDatestringOriginal publish date if this is a repost (null otherwise).
originalUrlstringOriginal URL if this is a repost (null otherwise).

Example output record:

{
"id": "123456",
"url": "https://jobtoday.com/jobs/senior-developer/123456",
"title": "Waiter/Waitress",
"company": "McDonald's",
"location": "London",
"city": "London",
"country": "INTL",
"contractType": "Permanent",
"workSchedule": "Full-time",
"salaryMin": 45000,
"salaryMax": 60750,
"salaryCurrency": "GBP",
"salaryPeriod": "YEAR",
"publishDate": "2026-04-15",
"publishDateISO": "2026-04-15",
"source": "jobtoday.com",
"scrapedAt": "2026-04-24T09:00:00.000Z",
"contentHash": "a3f1b2c4d5e67890",
"summary": "Waiter/Waitress · McDonald's · London",
"changeStatus": "NEW",
"isRepost": false,
"originalPublishDate": null,
"originalUrl": null
}

Examples

1 — Search for Waiter/Waitress roles in London

{
"searchQuery": "waiter",
"maxResults": 100
}

2 — All listings without filters

{
"searchQuery": "",
"maxResults": 500
}

3 — Scrape a specific search page directly via startUrls

{
"startUrls": [
{
"url": "https://jobtoday.com/jobs?q=waiter"
}
],
"maxResults": 50
}

4 — Daily feed — new listings only, past 24 hours, no reposts

{
"searchQuery": "",
"skipReposts": true,
"maxResults": 1000
}

💰 Pricing

$1.50 per 1,000 results — you only pay for successfully retrieved listings. Failed retries and filtered reposts are never charged.

ResultsCost
100~$0.15
1,000~$1.50
10,000~$15.00
100,000~$150.00

Flat-rate alternatives typically charge $29–$49/month regardless of usage.

Use the Max results cap in the input to control your spend exactly.


Performance

Run sizeApprox. time
100 listings~2 min
1,000 listings~15 min
10,000 listings~2.5 hours

Known limitations

  • Salary: Not all employers publish salary information — salaryMin and salaryMax may be null.
  • fetchDetails: Setting fetchDetails: false returns list-page fields only; description fields will be null.

Technical details

  • Source: jobtoday.com — Global (Hourly)'s job market
  • Memory: 256 MB
  • Repost storage: KeyValueStore jobtoday-job-dedup, 90-day TTL
  • Retry: Automatic retry on network errors, exponential backoff, 3 attempts per request

Additional services

Need a custom actor, additional filters, scheduled runs, or integration support? Send an email to info@unfencedgroup.nl — we build on request.


Part of the Unfenced Group European job board scraper portfolio — 50+ job markets covered. Built by unfenced-group · Issues? Open a ticket or send a message.