LinkedIn Jobs Scraper — Salary & Hiring Contacts
Pricing
$30.00 / 1,000 job analyzeds
LinkedIn Jobs Scraper — Salary & Hiring Contacts
Search LinkedIn jobs by keyword, location, or company and enrich any job posting URL — full description, salary, skills, and hiring-team contacts. Built for recruiters, sourcers, and lead-gen teams. No login or cookies.
Pricing
$30.00 / 1,000 job analyzeds
Rating
0.0
(0)
Developer
Andrey Afanasenko
Maintained by CommunityActor stats
0
Bookmarked
39
Total users
14
Monthly active users
2 days ago
Last modified
Categories
Share
LinkedIn Jobs Scraper
Search LinkedIn jobs by keyword, location, or company and enrich any job posting URL — full description, salary, skills, and hiring-team contacts. Built for recruiters, sourcers, and lead-gen teams. No login or cookies.
🎯 What it does
You feed the Actor LinkedIn job criteria — keywords + location, a list of company URLs, or specific job-posting URLs — it returns clean, structured rows ready for a CRM, sheet, or downstream agent.
| Mode | Input | What it returns |
|---|---|---|
1: Search Jobs (searchJobs) | Keywords + LinkedIn geo code + optional date / type / level / workplace filters | 10-field slim job rows (25 per upstream call, paginated). Cost cap: maxItemsMode1. |
2: Fetch Job Details (fetchJobDetails) | LinkedIn job posting URLs (one per line) | 1 row per URL, 36+ fields incl. full description, skills, salary, hiring team. Cost cap: maxItemsMode2. |
3: Search Company Jobs (searchCompanyJobs) | LinkedIn company URLs + optional keyword | Slim job rows for every open posting at the listed companies. Cost cap: maxItemsMode3. |
⚠️ Pick your mode first. All three modes have their own dedicated input section. Filling the wrong mode's fields is the #1 reason runs return zero rows. Always set "Operation Mode" before touching anything else.
- 10 slim fields per search row —
company,company_linkedin_url,company_logo,job_title,job_url,job_urn,location,posted_time,remote,salary. - 36 detail fields per enriched row — full
job_description,skills[],hiring_team[],salary_details,experience_level,industries[],employee_count,job_functions[],hq_*company fields, and 20+ more. - 7 advanced filters — title contains / NOT contains, company name allow-list, location contains, minimum salary, posted-within-N-days, remote-only — applied across all modes.
📦 What you get — output sample
One row per LinkedIn job. Slim columns (top of the row) always populated; detail columns only filled by Mode 2 (Fetch Job Details) and emit null in slim rows.
{"input": "https://www.linkedin.com/jobs/view/4344628911","company": "Qualcomm","company_linkedin_url": "https://www.linkedin.com/company/qualcomm","company_logo": "https://media.licdn.com/dms/image/.../qualcomm_logo","job_title": "New Graduate - AI SW SDK Engineer","job_url": "https://www.linkedin.com/jobs/view/4344628911","job_urn": "4344628911","location": "Santa Clara, CA","posted_time": "2026-05-18 11:33:11","remote": "On-site","salary": "","applies": 0,"benefits": [],"closed": false,"company_description": "Qualcomm is a world leader in 3G, 4G and next-generation wireless technologies …","company_id": "1337","company_name": "Qualcomm","company_public_id": "qualcomm","employee_count": 38000,"employee_range": "10001+","experience_level": "Entry level","expired": false,"follower_count": 4600000,"hiring_team": [{ "name": "Jane Recruiter", "title": "University Talent Acquisition", "profile_url": "https://www.linkedin.com/in/jane-r" }],"hq_address_line1": "5775 Morehouse Drive","hq_city": "San Diego","hq_country": "US","hq_full_address": "5775 Morehouse Drive, San Diego, CA, US","hq_postalcode": "92121","hq_region": "California","industries": ["Wireless Services", "Semiconductor Manufacturing"],"job_description": "We are looking for a New Graduate AI SW SDK Engineer to join …","job_functions": ["Engineering", "Information Technology"],"job_id": "4344628911","job_location": "Santa Clara, CA, United States","job_type": "Full-time","posted": "2026-05-18 11:33:11","remote_allow": "On-site","salary_details": null,"salary_display": "$110,000 - $140,000","skills": ["Python", "C++", "CUDA", "ONNX", "PyTorch"],"specialities": ["wireless", "semiconductor", "5G"],"views": 1240}
Detail columns (applies through views) are null in rows produced by Mode 1 (Search Jobs) and Mode 3 (Search Company Jobs); they only populate in Mode 2 (Fetch Job Details).
⚡ How to use
- Choose Operation Mode at the top of the input panel.
- The matching
🎯 Mode Nsection appears below — fill its primary field (keywords / job URLs / company URLs). - Optionally tune the
🔬 Advanced filteringsection. - Set the per-mode cap (
maxItemsModeN) if you want a hard ceiling. Leave at 0 for unlimited (paid plan only). - Click Save & Start.
If you start a run with no input filled in, the Actor uses a built-in demo seed and caps the output at 10 rows — see the USER_MESSAGE record in the run's Storage tab.
Recruiting a daily delta? Save your filled-in search as an Apify Task and schedule it to run daily — diff against yesterday's dataset to catch new postings the moment they appear.
🎯 Example tasks
Ready-to-run examples — each opens a pre-configured task you can run in one click (no setup):
- Scrape LinkedIn jobs by keyword — Search LinkedIn job postings by keyword and location — export title, company, location, salary, posted date and apply link.
- Find Data Analyst jobs on LinkedIn — Export current Data Analyst job openings from LinkedIn — company, location, salary, posted date and direct apply link.
- Search Product Manager jobs on LinkedIn — Find Product Manager roles on LinkedIn by location — export company, title, salary, posted date and apply link as structured data.
- Scrape remote jobs on LinkedIn — Export current remote job openings from LinkedIn by keyword — company, title, salary, posted date and direct apply link as structured data.
- Find Software Engineer jobs on LinkedIn — Export current Software Engineer job openings from LinkedIn — company, location, salary, posted date and direct apply link as structured data.
- Scrape jobs by company on LinkedIn — Get every open job at any company from its LinkedIn page — title, location, salary, posted date and apply link as structured data.
🛠 Operation modes
🎯 Mode 1: Search Jobs
Search LinkedIn jobs by keyword + location with optional filters (date posted, job type, experience level, workplace type, Easy Apply, low-applicant). 25 jobs per upstream call; the Actor paginates until your cap is reached.
Required: searchJobsKeywords (free text). Geo defaults to United States.
Geo targeting — four fields, most specific non-empty wins (top to bottom on the input panel):
- Country (
searchJobsGeoCode) — 198 countries, required default (US). - State / province / region (
searchJobsState, optional) — ~1500 entries covering top 70 markets. Overrides Country. - Major city (
searchJobsCity, optional) — top 1000 cities globally by population. Overrides State + Country. - Custom Location (
searchJobsLocationCustom, optional) — type ANY LinkedIn-indexed place ("Cluj-Napoca", "Tartu", "Pune", "Brooklyn") or paste a numeric LinkedIn geoId. Resolved live at run start. Overrides everything above.
⚠️ Make sure Operation Mode is "Mode 1: Search Jobs". Mode-2 / Mode-3 fields are ignored here.
🎯 Mode 2: Fetch Job Details
Enrich an array of LinkedIn job-posting URLs with the full 36-field detail (description, skills, salary, hiring team, …). Use this after Mode 1 to drill into the postings you care about.
Required: fetchJobDetailsUrls (array of LinkedIn job URLs). Optional toggles: include skills / include hiring team (both default on).
If some links return nothing (the posting was closed, filled, or removed), the run report says exactly how many — empty links are never charged.
⚠️ Make sure Operation Mode is "Mode 2: Fetch Job Details". Mode-1 / Mode-3 fields are ignored here.
🎯 Mode 3: Search Company Jobs
Find every open job at one or more LinkedIn companies. The Actor resolves each company URL to its LinkedIn numeric id, then runs a single search across all of them — all locations, every role. Leave the keyword blank to get the complete listing; add one core keyword (e.g. "engineer") only when you need to narrow.
Some companies hire on their own careers site and list no jobs on their LinkedIn page. When a search comes back empty, the run report names each company with its live open-roles count — so you can tell "no roles listed" apart from "keywords too narrow".
Required: searchCompanyJobsCompanyUrls (array of company LinkedIn URLs). Optional: searchCompanyJobsKeywords. To limit by location, set the Mode 1 location fields — otherwise Mode 3 searches worldwide. Large companies can list 1,000+ open roles — set maxItemsMode3 to bound cost.
⚠️ Make sure Operation Mode is "Mode 3: Search Company Jobs". Mode-1 / Mode-2 primary fields are ignored here (only the Mode-1 location fields carry over, and only when you change them).
💸 Pricing
PAY_PER_EVENT — one event, one price, across all modes.
| Event | Price | When it fires |
|---|---|---|
JOB_ANALYZED | $0.030 per job | Once per row pushed to the dataset (any mode). |
Apify platform compute (memory + storage + bandwidth) is on top of that and small for this workload — a 20-job Mode 1 run typically costs well under $0.05 in platform overhead.
🔬 Advanced filtering
Filters apply after the upstream fetch, before the row lands in the dataset. The paid event still fires on the raw fetch — filters narrow your output, not your bill.
| Filter | Effect |
|---|---|
filterTitleContains | Drop rows whose job title doesn't contain this substring. |
filterTitleNotContains | Drop rows whose job title contains this substring (great for excluding "senior" or "intern"). |
filterCompanyNames | Allow-list — drop rows whose company name doesn't match one of the entries. |
filterLocationContains | Substring match against location. |
filterSalaryMin | Drop rows whose listed salary is below this. Note: LinkedIn rarely surfaces salary on search rows, so any non-zero floor drops most of them. |
filterPostedWithinDays | Drop rows posted more than N days ago. |
filterRemoteOnly | Drop rows not flagged remote. |
🎁 Free plan
The free plan saves up to 20 jobs per run, across all modes. Need more? When a run hits the cap, its USER_MESSAGE (Storage tab) shows exactly how many jobs matched — any paid Apify plan lifts the cap, and re-running the same search returns the full result set.
📊 Output destinations
The Actor writes to the standard Apify dataset, which is reachable as JSON / CSV / Excel / RSS / HTML / XML via the Dataset API. Ready-to-pipe into:
- Google Sheets — via the Apify ↔ Sheets integration.
- Airtable — via Apify ↔ Airtable.
- Webhooks — every successful run can POST to your endpoint.
🔑 Use cases
- Recruiting — daily delta of postings matching your sourcing criteria.
- Lead generation — hiring-team contacts for ABM / outbound (Mode 2 with
include_hiring_teamon). - Market intel — track who is hiring at competitors (Mode 3 with their company URLs).
- Salary benchmarking — enrich a list of postings and aggregate
salary_displayby role / location.
❓ FAQ
Q: Do I need a LinkedIn account, cookies, or login? No. You don't connect your LinkedIn account and there's nothing to log in to — just enter keywords, company URLs, or job URLs and run. Only public LinkedIn job data is returned.
Q: My run returned zero rows.
99% of the time this is "wrong mode selected." Open the input panel, check Operation Mode at the top, then make sure the matching 🎯 Mode N section is the one you filled in.
Q: How do I get more results from a search? Keep your keywords to the core job title — extra words ("senior", "MBA", "remote") sharply narrow results and can return nothing. Broaden the location, widen "Date posted" to "Past month" or "Any time", and turn off narrow filters like "Easy Apply only". A single clear title in a big market (e.g. "Data Analyst" in the United States) returns the most.
Q: Salary is empty on most rows.
LinkedIn rarely shows salary on search-result rows. Enrich the postings you care about via Mode 2 — salary_display is more often populated there.
Q: My target city / town isn't in the City dropdown. Use the Custom Location field — type any LinkedIn-indexed place (e.g. "Cluj-Napoca", "Tartu", "Brooklyn"). The Actor resolves it live against LinkedIn's typeahead at run start and logs the resolved name + ID so you can verify the pick.
Q: I already have a LinkedIn geoId from the URL — can I paste it directly?
Yes. Paste the numeric ID (e.g. 102095887 for California) into Custom Location. The Actor detects 6–10 digit numeric inputs and skips the typeahead resolve.
Q: Are filters charged?
The JOB_ANALYZED event fires on the raw upstream fetch. Filters in the 🔬 Advanced filtering section run after the fetch, so they narrow your output but not your bill. If "all rows filtered" is a problem, loosen the filters and post-filter downstream.
Q: Can I search several job titles at once?
Yes — separate them with commas in the keyword field (e.g. Risk Analyst, Data Analyst, Financial Analyst). The Actor searches for jobs matching any of them. Custom Location works the same way: a comma list resolves to the first place LinkedIn recognises.
Q: Can I sort by posting date?
Yes — set searchJobsSortBy to "Most recent" in Mode 1.
Q: How many jobs can I get in one run?
The free plan saves up to 20 jobs per run, across all modes. On a paid plan there's no cap — you're limited only by the per-mode cost ceiling you set (maxItemsModeN). If a free run hits the limit, the run's USER_MESSAGE tells you how many more matched.
Q: How do I get every open role at a company? Use Mode 3 with the company's LinkedIn URL and leave the keyword field blank — you get the complete listing, all locations. If the run comes back empty, the run report shows the company's live open-roles count: some companies hire on their own careers site and list nothing on LinkedIn.
Q: Can I bulk-enrich a big list of job posting URLs?
Yes. Mode 2 takes many job URLs at once and returns the full 36-field detail per posting. For very large lists, split into batches and set maxItemsMode2 to cap spend per run.
Q: Can I schedule this to run daily? Yes — save your filled-in input as an Apify Task and add a schedule to it. Each scheduled run uses your saved input; free-plan scheduled runs are capped at 20 jobs per run like any other run.
⏱ Timing & runtime
- Mode 1: ~2-4 seconds per 25-job page — a full free-plan run (20 jobs) finishes in seconds.
- Mode 2: ~2-3 seconds per job URL (sequential — the detail endpoint is single-job).
- Mode 3: 1 extra company-id resolve call per company URL, then same as Mode 1.
Default Apify timeout is fine for runs ≤ a few hundred rows; bump the timeout in Run Options for larger sweeps.
🤝 Related Actors
| You start with… | You want to find… | Use this actor |
|---|---|---|
| Job criteria / job-posting URLs / company URLs | Job listings + full description, salary, skills, hiring team | This actor |
| LinkedIn profile URLs or search criteria | Profiles, companies, decision-makers (70+ fields) | LinkedIn Profile Scraper |
| Instagram handles | Profile data + 5 discovery modes (followers, similar, keyword, location) | Instagram Profile Scraper |
| TikTok profile / hashtag | Profile data + posts | TikTok Profile Scraper |
| YouTube channel URL / handle | Channel + video metadata | YouTube Channel Scraper |
| US ZIP / address | Property listings + market data | Zillow Scraper |
🆘 Support
Found a bug, a missing field, or a posting that didn't enrich? Use the Issues tab on this Actor's Apify Store page — it's the fastest path to a fix.
💡 Tips & Best Practices
Getting max results
- Mode 1: keep keywords to the core job title; comma-separate several titles for an OR search (
Risk Analyst, Data Analyst). - Geo targeting: the most specific non-empty field wins — Custom Location beats City beats State beats Country.
- Mode 3: leave the keyword blank to get every open role at the listed companies; add one core keyword only when you need to narrow.
Cost optimization
- Use
maxItemsModeNaggressively when testing — 5-10 rows to validate the output shape, then scale up. - Shortlist with Mode 1's slim rows first, then enrich only the postings you care about in Mode 2 — both cost $0.030/row, so enriching everything you searched doubles the spend.
- Filters don't reduce billing (they run after the fetch) — narrow with keywords and location first, filter second.
Performance
- Mode 1: ~2-4 seconds per 25-job page. Mode 2: ~2-3 seconds per URL (sequential). Mode 3: one extra company-resolve call per company URL.
- The live status page shows progress in real time; the default Apify timeout is fine for runs up to a few hundred rows.
Data quality
salaryon search rows is often empty — Mode 2'ssalary_displayis populated far more often.- Job postings expire quickly; enrich URLs via Mode 2 soon after collecting them.
hiring_teamcontacts appear when LinkedIn shows them publicly on the posting — not every posting lists its recruiter.
⚖️ Disclaimer
This Actor scrapes only publicly available LinkedIn data. You are responsible for using the data in accordance with LinkedIn's Terms of Service, applicable privacy laws (GDPR, CCPA), and ethical-use guidelines. The Actor does not scrape private data, personal feeds, or content behind login walls.
📋 Changelog
See ./CHANGELOG.md for the version history.