Glassdoor Jobs Scraper | Remove Duplicate Jobs
3 days trial then $5.00/month - No credit card required now
This Actor may be unreliable while under maintenance. Would you like to try a similar Actor instead?
See alternative ActorsGlassdoor Jobs Scraper | Remove Duplicate Jobs
3 days trial then $5.00/month - No credit card required now
Glassdoor Jobs Scraper | Remove Duplicate Jobs. The Glassdoor jobs scraper allows you to collect jobs in 2 ways: By providing one or more start URLs, or By entering keyword-based search queries. You can use either method individually or combine both.
You can access the Glassdoor Jobs Scraper | Remove Duplicate Jobs programmatically from your own applications by using the Apify API. You can choose the language preference from below. To use the Apify API, you’ll need an Apify account and your API token, found in Integrations settings in Apify Console.
1{
2 "openapi": "3.0.1",
3 "info": {
4 "version": "0.0",
5 "x-build-id": "lqYHKpCQBDe8vb9mF"
6 },
7 "servers": [
8 {
9 "url": "https://api.apify.com/v2"
10 }
11 ],
12 "paths": {
13 "/acts/cheap_scraper~glassdoor-job-scraper/run-sync-get-dataset-items": {
14 "post": {
15 "operationId": "run-sync-get-dataset-items-cheap_scraper-glassdoor-job-scraper",
16 "x-openai-isConsequential": false,
17 "summary": "Executes an Actor, waits for its completion, and returns Actor's dataset items in response.",
18 "tags": [
19 "Run Actor"
20 ],
21 "requestBody": {
22 "required": true,
23 "content": {
24 "application/json": {
25 "schema": {
26 "$ref": "#/components/schemas/inputSchema"
27 }
28 }
29 }
30 },
31 "parameters": [
32 {
33 "name": "token",
34 "in": "query",
35 "required": true,
36 "schema": {
37 "type": "string"
38 },
39 "description": "Enter your Apify token here"
40 }
41 ],
42 "responses": {
43 "200": {
44 "description": "OK"
45 }
46 }
47 }
48 },
49 "/acts/cheap_scraper~glassdoor-job-scraper/runs": {
50 "post": {
51 "operationId": "runs-sync-cheap_scraper-glassdoor-job-scraper",
52 "x-openai-isConsequential": false,
53 "summary": "Executes an Actor and returns information about the initiated run in response.",
54 "tags": [
55 "Run Actor"
56 ],
57 "requestBody": {
58 "required": true,
59 "content": {
60 "application/json": {
61 "schema": {
62 "$ref": "#/components/schemas/inputSchema"
63 }
64 }
65 }
66 },
67 "parameters": [
68 {
69 "name": "token",
70 "in": "query",
71 "required": true,
72 "schema": {
73 "type": "string"
74 },
75 "description": "Enter your Apify token here"
76 }
77 ],
78 "responses": {
79 "200": {
80 "description": "OK",
81 "content": {
82 "application/json": {
83 "schema": {
84 "$ref": "#/components/schemas/runsResponseSchema"
85 }
86 }
87 }
88 }
89 }
90 }
91 },
92 "/acts/cheap_scraper~glassdoor-job-scraper/run-sync": {
93 "post": {
94 "operationId": "run-sync-cheap_scraper-glassdoor-job-scraper",
95 "x-openai-isConsequential": false,
96 "summary": "Executes an Actor, waits for completion, and returns the OUTPUT from Key-value store in response.",
97 "tags": [
98 "Run Actor"
99 ],
100 "requestBody": {
101 "required": true,
102 "content": {
103 "application/json": {
104 "schema": {
105 "$ref": "#/components/schemas/inputSchema"
106 }
107 }
108 }
109 },
110 "parameters": [
111 {
112 "name": "token",
113 "in": "query",
114 "required": true,
115 "schema": {
116 "type": "string"
117 },
118 "description": "Enter your Apify token here"
119 }
120 ],
121 "responses": {
122 "200": {
123 "description": "OK"
124 }
125 }
126 }
127 }
128 },
129 "components": {
130 "schemas": {
131 "inputSchema": {
132 "type": "object",
133 "properties": {
134 "startUrls": {
135 "title": "Start URLs",
136 "type": "array",
137 "description": "One or more URLs of the pages where the crawler will start. Note that the Actor will additionally crawl job page data.",
138 "items": {
139 "type": "object",
140 "required": [
141 "url"
142 ],
143 "properties": {
144 "url": {
145 "type": "string",
146 "title": "URL of a web page",
147 "format": "uri"
148 }
149 }
150 }
151 },
152 "keyword": {
153 "title": "Keyword",
154 "type": "string",
155 "description": "Keyword to search for. (e.g., Software Engineer). JSON field name: `keyword`"
156 },
157 "baseUrl": {
158 "title": "Country",
159 "enum": [
160 "https://www.glassdoor.com",
161 "https://www.glassdoor.com.ar",
162 "https://www.glassdoor.com.au",
163 "https://www.glassdoor.at",
164 "https://nl.www.glassdoor.be",
165 "https://fr.www.glassdoor.be",
166 "https://www.glassdoor.com.br",
167 "https://www.glassdoor.ca",
168 "https://fr.www.glassdoor.ca",
169 "https://www.glassdoor.de",
170 "https://www.glassdoor.es",
171 "https://www.glassdoor.fr",
172 "https://www.glassdoor.hk",
173 "https://www.glassdoor.co.in",
174 "https://www.glassdoor.ie",
175 "https://www.glassdoor.it",
176 "https://www.glassdoor.com.mx",
177 "https://www.glassdoor.nl",
178 "https://www.glassdoor.co.nz",
179 "https://www.glassdoor.sg",
180 "https://www.glassdoor.ch",
181 "https://www.glassdoor.co.uk"
182 ],
183 "type": "string",
184 "description": "Select country (default is USA) Enhance accuracy by selecting the associated country. Data is drawn directly from country-specific Glassdoor.com platforms, ensuring relevant outcomes for your location. JSON field name: `baseUrl`",
185 "default": "https://www.glassdoor.com"
186 },
187 "location": {
188 "title": "Location",
189 "type": "string",
190 "description": "Location to search in. JSON field name: `location`"
191 },
192 "companyName": {
193 "title": "Company Name",
194 "type": "string",
195 "description": "Company name to search for. JSON field name: `companyName`"
196 },
197 "minSalary": {
198 "title": "Minimum Salary",
199 "type": "integer",
200 "description": "Minimum salary in USD. Default is 0. JSON field name: `minSalary`"
201 },
202 "maxSalary": {
203 "title": "Max Salary",
204 "type": "integer",
205 "description": "Maximum salary in USD. JSON field name: `maxSalary`"
206 },
207 "fromAge": {
208 "title": "Publication Age",
209 "minimum": 1,
210 "maximum": 30,
211 "type": "integer",
212 "description": "How old publications should be in Days. Default is ANY. JSON field name: `fromAge`"
213 },
214 "radius": {
215 "title": "Radius",
216 "enum": [
217 "0",
218 "6",
219 "12",
220 "18",
221 "31",
222 "62",
223 "124"
224 ],
225 "type": "string",
226 "description": "Radius in kilometers. Default is 30 Km/18 Miles. JSON field name: `radius`"
227 },
228 "applicationType": {
229 "title": "Easy apply only",
230 "type": "boolean",
231 "description": "Easy apply only. Default is false. JSON field name: `applicationType`",
232 "default": false
233 },
234 "remoteWorkType": {
235 "title": "Remote Work",
236 "type": "boolean",
237 "description": "Remote work. Default is ANY. JSON field name: `remoteWorkType`",
238 "default": false
239 },
240 "seniorityType": {
241 "title": "Seniority",
242 "enum": [
243 "internship",
244 "entrylevel",
245 "midseniorlevel",
246 "director",
247 "executive"
248 ],
249 "type": "string",
250 "description": "Seniority. Default is All. JSON field name: `seniorityType`"
251 },
252 "minRating": {
253 "title": "Minimum Rating",
254 "minimum": 0,
255 "maximum": 5,
256 "type": "integer",
257 "description": "Minimum rating. Default is 0. JSON field name: `minRating`"
258 },
259 "saveOnlyUniqueItems": {
260 "title": "Save Only Unique Items",
261 "type": "boolean",
262 "description": "If enabled, only unique items will be saved. Default is false. JSON field name: `saveOnlyUniqueItems`",
263 "default": false
264 },
265 "maxItems": {
266 "title": "Maximum Items",
267 "maximum": 10000,
268 "type": "integer",
269 "description": "Maximum number of items to scrape. Default is none, it will scrape all the jobs it finds. JSON field name: `maxItems`"
270 },
271 "includeNoSalaryJob": {
272 "title": "Include No Salary Job",
273 "type": "boolean",
274 "description": "Include jobs with no salary. Default is true. JSON field name `includeNoSalaryJob`",
275 "default": true
276 },
277 "proxy": {
278 "title": "Proxy configuration",
279 "type": "object",
280 "description": "Select proxies to be used by your crawler. JSON field name: `proxy`"
281 }
282 }
283 },
284 "runsResponseSchema": {
285 "type": "object",
286 "properties": {
287 "data": {
288 "type": "object",
289 "properties": {
290 "id": {
291 "type": "string"
292 },
293 "actId": {
294 "type": "string"
295 },
296 "userId": {
297 "type": "string"
298 },
299 "startedAt": {
300 "type": "string",
301 "format": "date-time",
302 "example": "2025-01-08T00:00:00.000Z"
303 },
304 "finishedAt": {
305 "type": "string",
306 "format": "date-time",
307 "example": "2025-01-08T00:00:00.000Z"
308 },
309 "status": {
310 "type": "string",
311 "example": "READY"
312 },
313 "meta": {
314 "type": "object",
315 "properties": {
316 "origin": {
317 "type": "string",
318 "example": "API"
319 },
320 "userAgent": {
321 "type": "string"
322 }
323 }
324 },
325 "stats": {
326 "type": "object",
327 "properties": {
328 "inputBodyLen": {
329 "type": "integer",
330 "example": 2000
331 },
332 "rebootCount": {
333 "type": "integer",
334 "example": 0
335 },
336 "restartCount": {
337 "type": "integer",
338 "example": 0
339 },
340 "resurrectCount": {
341 "type": "integer",
342 "example": 0
343 },
344 "computeUnits": {
345 "type": "integer",
346 "example": 0
347 }
348 }
349 },
350 "options": {
351 "type": "object",
352 "properties": {
353 "build": {
354 "type": "string",
355 "example": "latest"
356 },
357 "timeoutSecs": {
358 "type": "integer",
359 "example": 300
360 },
361 "memoryMbytes": {
362 "type": "integer",
363 "example": 1024
364 },
365 "diskMbytes": {
366 "type": "integer",
367 "example": 2048
368 }
369 }
370 },
371 "buildId": {
372 "type": "string"
373 },
374 "defaultKeyValueStoreId": {
375 "type": "string"
376 },
377 "defaultDatasetId": {
378 "type": "string"
379 },
380 "defaultRequestQueueId": {
381 "type": "string"
382 },
383 "buildNumber": {
384 "type": "string",
385 "example": "1.0.0"
386 },
387 "containerUrl": {
388 "type": "string"
389 },
390 "usage": {
391 "type": "object",
392 "properties": {
393 "ACTOR_COMPUTE_UNITS": {
394 "type": "integer",
395 "example": 0
396 },
397 "DATASET_READS": {
398 "type": "integer",
399 "example": 0
400 },
401 "DATASET_WRITES": {
402 "type": "integer",
403 "example": 0
404 },
405 "KEY_VALUE_STORE_READS": {
406 "type": "integer",
407 "example": 0
408 },
409 "KEY_VALUE_STORE_WRITES": {
410 "type": "integer",
411 "example": 1
412 },
413 "KEY_VALUE_STORE_LISTS": {
414 "type": "integer",
415 "example": 0
416 },
417 "REQUEST_QUEUE_READS": {
418 "type": "integer",
419 "example": 0
420 },
421 "REQUEST_QUEUE_WRITES": {
422 "type": "integer",
423 "example": 0
424 },
425 "DATA_TRANSFER_INTERNAL_GBYTES": {
426 "type": "integer",
427 "example": 0
428 },
429 "DATA_TRANSFER_EXTERNAL_GBYTES": {
430 "type": "integer",
431 "example": 0
432 },
433 "PROXY_RESIDENTIAL_TRANSFER_GBYTES": {
434 "type": "integer",
435 "example": 0
436 },
437 "PROXY_SERPS": {
438 "type": "integer",
439 "example": 0
440 }
441 }
442 },
443 "usageTotalUsd": {
444 "type": "number",
445 "example": 0.00005
446 },
447 "usageUsd": {
448 "type": "object",
449 "properties": {
450 "ACTOR_COMPUTE_UNITS": {
451 "type": "integer",
452 "example": 0
453 },
454 "DATASET_READS": {
455 "type": "integer",
456 "example": 0
457 },
458 "DATASET_WRITES": {
459 "type": "integer",
460 "example": 0
461 },
462 "KEY_VALUE_STORE_READS": {
463 "type": "integer",
464 "example": 0
465 },
466 "KEY_VALUE_STORE_WRITES": {
467 "type": "number",
468 "example": 0.00005
469 },
470 "KEY_VALUE_STORE_LISTS": {
471 "type": "integer",
472 "example": 0
473 },
474 "REQUEST_QUEUE_READS": {
475 "type": "integer",
476 "example": 0
477 },
478 "REQUEST_QUEUE_WRITES": {
479 "type": "integer",
480 "example": 0
481 },
482 "DATA_TRANSFER_INTERNAL_GBYTES": {
483 "type": "integer",
484 "example": 0
485 },
486 "DATA_TRANSFER_EXTERNAL_GBYTES": {
487 "type": "integer",
488 "example": 0
489 },
490 "PROXY_RESIDENTIAL_TRANSFER_GBYTES": {
491 "type": "integer",
492 "example": 0
493 },
494 "PROXY_SERPS": {
495 "type": "integer",
496 "example": 0
497 }
498 }
499 }
500 }
501 }
502 }
503 }
504 }
505 }
506}
Glassdoor Jobs Scraper | Remove Duplicate Jobs OpenAPI definition
OpenAPI is a standard for designing and describing RESTful APIs, allowing developers to define API structure, endpoints, and data formats in a machine-readable way. It simplifies API development, integration, and documentation.
OpenAPI is effective when used with AI agents and GPTs by standardizing how these systems interact with various APIs, for reliable integrations and efficient communication.
By defining machine-readable API specifications, OpenAPI allows AI models like GPTs to understand and use varied data sources, improving accuracy. This accelerates development, reduces errors, and provides context-aware responses, making OpenAPI a core component for AI applications.
You can download the OpenAPI definitions for Glassdoor Jobs Scraper | Remove Duplicate Jobs from the options below:
If you’d like to learn more about how OpenAPI powers GPTs, read our blog post.
You can also check out our other API clients:
Actor Metrics
3 monthly users
-
1 star
88% runs succeeded
Created in Jan 2025
Modified 4 days ago