Karriere.at Scraper
Pricing
from $1.50 / 1,000 results
Karriere.at Scraper
Scrape karriere.at — Austria's largest job board — for structured job listings. Filter by keyword, location, employment type, salary range and sector. Full descriptions in HTML, text and Markdown. Repost detection & daysOld filtering. No API key required.
Pricing
from $1.50 / 1,000 results
Rating
0.0
(0)
Developer
Unfenced Group
Actor stats
1
Bookmarked
3
Total users
2
Monthly active users
5 hours ago
Last modified
Categories
Share

Scrape structured job listings from Karriere.at — Austria. 20,000+ active listings. No API key required.
Why this scraper?
🇦🇹 Austria's #1 job platform
Karriere.at is the leading job portal in Austria, covering all major industries and regions from Vienna to Vorarlberg.
📄 Full job descriptions
Enable fetchDetails to retrieve complete job descriptions in all three formats.
💰 Austrian salary data
Salary ranges in EUR extracted and normalised where published.
🔎 Advanced filtering
Filter by work type, career level, and industry.
🔄 Repost detection
Cross-run deduplication with a 90-day TTL. Use skipReposts: true for new-only feeds.
⚙️ No API key required
Runs without any third-party credentials.
Input parameters
| Parameter | Type | Description | Default |
|---|---|---|---|
searchQuery | string | Job title, keyword, or skill to search for. | — |
location | string | City or region to filter by. Leave empty to search all locations. | — |
maxResults | integer | Maximum number of results to return. | 5 |
daysOld | integer | Only return listings published within the last N days. | — |
employmentType | string | Employment type filter. | — |
radius | string | Search radius in km from the specified location. | — |
skipReposts | boolean | Skip listings already seen in previous runs (90-day deduplication window). | false |
fetchDetails | boolean | Fetch full job description from each listing detail page. Disable for faster list-only results. | true |
startUrls | array | List of specific URLs to scrape. Bypasses the search input. | — |
Output schema
Each result contains the following fields.
Always present:
| Field | Type | Description |
|---|---|---|
id | string | Unique job listing ID from the source platform. |
url | string | Direct URL to the job listing. |
title | string | Job title as published. |
company | string | Employer / company name. |
location | string | Full location string as published. |
city | string | City of the work location. |
country | string | Country code (ISO 3166-1 alpha-2). |
contractType | string | Contract type (permanent, contract, temporary, etc.). |
workSchedule | string | Work schedule (full-time, part-time, etc.). |
salaryMin | number | Minimum salary (null if not published by employer). |
salaryMax | number | Maximum salary (null if not published by employer). |
salaryCurrency | string | ISO 4217 currency code (null if no salary published). |
salaryPeriod | string | Salary period: YEAR / MONTH / WEEK / DAY / HOUR. |
publishDate | string | Publication date (YYYY-MM-DD). |
publishDateISO | string | Publication date in ISO 8601 format. |
source | string | Source domain name. |
scrapedAt | string | ISO 8601 timestamp of when this item was scraped. |
contentHash | string | MD5 hash of key fields for change detection (16 chars). |
summary | string | Human-readable one-line summary of the listing. |
changeStatus | string | Change status: NEW / MODIFIED / UNCHANGED. |
isRepost | boolean | True if this listing was seen in a previous run (90-day window). |
originalPublishDate | string | Original publish date if this is a repost (null otherwise). |
originalUrl | string | Original URL if this is a repost (null otherwise). |
With fetchDetails: true (default):
| Field | Type | Description |
|---|---|---|
descriptionHtml | string | Full job description as raw HTML (null if fetchDetails is false). |
descriptionText | string | Full job description as plain text (null if fetchDetails is false). |
descriptionMarkdown | string | Full job description in Markdown format (null if fetchDetails is false). |
Example output record:
{"id": "123456","url": "https://www.karriere.at/jobs/senior-developer/123456","title": "Software-Entwickler","company": "ÖBB","location": "Wien","city": "Wien","country": "AT","contractType": "Permanent","workSchedule": "Full-time","salaryMin": 45000,"salaryMax": 60750,"salaryCurrency": "EUR","salaryPeriod": "YEAR","publishDate": "2026-04-15","publishDateISO": "2026-04-15","source": "karriere.at","scrapedAt": "2026-04-24T09:00:00.000Z","contentHash": "a3f1b2c4d5e67890","summary": "Software-Entwickler · ÖBB · Wien","changeStatus": "NEW","isRepost": false,"originalPublishDate": null,"originalUrl": null,"descriptionHtml": "<p>We are looking for an experienced professional to join our growing team...</p>","descriptionText": "We are looking for an experienced professional to join our growing team...","descriptionMarkdown": "We are looking for an experienced professional to join our growing team..."}
Examples
1 — Search for Software-Entwickler roles in Wien
{"searchQuery": "Entwickler","location": "Wien","maxResults": 100}
2 — All listings without filters
{"searchQuery": "","maxResults": 500}
3 — Scrape a specific search page directly via startUrls
{"startUrls": [{"url": "https://www.karriere.at/jobs?q=Entwickler"}],"maxResults": 50}
4 — Daily feed — new listings only, past 24 hours, no reposts
{"searchQuery": "","fetchDetails": false,"daysOld": 1,"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.
| Results | Cost |
|---|---|
| 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 size | Approx. 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 —
salaryMinandsalaryMaxmay benull. - fetchDetails: Setting
fetchDetails: falsereturns list-page fields only; description fields will benull.
Technical details
- Source: karriere.at — Austria's job market
- Memory: 256 MB
- Repost storage: KeyValueStore
karriere-at-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.