
Google Shopping
Pricing
Pay per event

Google Shopping
High-quality Google Shopping Scraper. Rich data results.
0.0 (0)
Pricing
Pay per event
5
Monthly users
25
Runs succeeded
>99%
Response time
5.1 hours
Last modified
7 days ago
You can access the Google Shopping programmatically from your own applications by using the Apify API. You can also 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": "7p3R0pmXjCcaJSV3o"
6 },
7 "servers": [
8 {
9 "url": "https://api.apify.com/v2"
10 }
11 ],
12 "paths": {
13 "/acts/dan.scraper~google-shopping/run-sync-get-dataset-items": {
14 "post": {
15 "operationId": "run-sync-get-dataset-items-dan.scraper-google-shopping",
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/dan.scraper~google-shopping/runs": {
50 "post": {
51 "operationId": "runs-sync-dan.scraper-google-shopping",
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/dan.scraper~google-shopping/run-sync": {
93 "post": {
94 "operationId": "run-sync-dan.scraper-google-shopping",
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 "required": [
134 "queries"
135 ],
136 "properties": {
137 "queries": {
138 "title": "Search Queries",
139 "type": "array",
140 "description": "List of Google Shopping search query.",
141 "items": {
142 "type": "string"
143 }
144 },
145 "locationUule": {
146 "title": "Search Location - UULE location code",
147 "type": "string",
148 "description": "The code for geolocation of search results. It's passed to Google Search as the <code>uule</code> URL query parameter. You can use the <a href='https://padavvan.github.io/' target='_blank'>UULE code generator</a>. Learn more about <a href='https://moz.com/ugc/geolocation-the-ultimate-tip-to-emulate-local-search' target='_blank'>emulating local search</a>. <br><br> <b>Notice</b>: This parameter is the ONLY way to get Google Shopping results from a specific location."
149 },
150 "maxPagesPerQuery": {
151 "title": "Max pages per query",
152 "minimum": 1,
153 "type": "integer",
154 "description": "The maximum number of search result pages crawled for each search query or URL."
155 },
156 "countryCode": {
157 "title": "Country",
158 "enum": [
159 "",
160 "af",
161 "al",
162 "dz",
163 "as",
164 "ad",
165 "ao",
166 "ai",
167 "aq",
168 "ag",
169 "ar",
170 "am",
171 "aw",
172 "au",
173 "at",
174 "az",
175 "bs",
176 "bh",
177 "bd",
178 "bb",
179 "by",
180 "be",
181 "bz",
182 "bj",
183 "bm",
184 "bt",
185 "bo",
186 "ba",
187 "bw",
188 "bv",
189 "br",
190 "io",
191 "bn",
192 "bg",
193 "bf",
194 "bi",
195 "kh",
196 "cm",
197 "ca",
198 "cv",
199 "ky",
200 "cf",
201 "td",
202 "cl",
203 "cn",
204 "cx",
205 "cc",
206 "co",
207 "km",
208 "cg",
209 "cd",
210 "ck",
211 "cr",
212 "ci",
213 "hr",
214 "cu",
215 "cy",
216 "cz",
217 "dk",
218 "dj",
219 "dm",
220 "do",
221 "ec",
222 "eg",
223 "sv",
224 "gq",
225 "er",
226 "ee",
227 "et",
228 "fk",
229 "fo",
230 "fj",
231 "fi",
232 "fr",
233 "gf",
234 "pf",
235 "tf",
236 "ga",
237 "gm",
238 "ge",
239 "de",
240 "gh",
241 "gi",
242 "gr",
243 "gl",
244 "gd",
245 "gp",
246 "gu",
247 "gt",
248 "gn",
249 "gw",
250 "gy",
251 "ht",
252 "hm",
253 "va",
254 "hn",
255 "hk",
256 "hu",
257 "is",
258 "in",
259 "id",
260 "ir",
261 "iq",
262 "ie",
263 "il",
264 "it",
265 "jm",
266 "jp",
267 "jo",
268 "kz",
269 "ke",
270 "ki",
271 "kp",
272 "kr",
273 "kw",
274 "kg",
275 "la",
276 "lv",
277 "lb",
278 "ls",
279 "lr",
280 "ly",
281 "li",
282 "lt",
283 "lu",
284 "mo",
285 "mk",
286 "mg",
287 "mw",
288 "my",
289 "mv",
290 "ml",
291 "mt",
292 "mh",
293 "mq",
294 "mr",
295 "mu",
296 "yt",
297 "mx",
298 "fm",
299 "md",
300 "mc",
301 "mn",
302 "ms",
303 "ma",
304 "mz",
305 "mm",
306 "na",
307 "nr",
308 "np",
309 "nl",
310 "an",
311 "nc",
312 "nz",
313 "ni",
314 "ne",
315 "ng",
316 "nu",
317 "nf",
318 "mp",
319 "no",
320 "om",
321 "pk",
322 "pw",
323 "ps",
324 "pa",
325 "pg",
326 "py",
327 "pe",
328 "ph",
329 "pn",
330 "pl",
331 "pt",
332 "pr",
333 "qa",
334 "re",
335 "ro",
336 "ru",
337 "rw",
338 "sh",
339 "kn",
340 "lc",
341 "pm",
342 "vc",
343 "ws",
344 "sm",
345 "st",
346 "sa",
347 "sn",
348 "cs",
349 "sc",
350 "sl",
351 "sg",
352 "sk",
353 "si",
354 "sb",
355 "so",
356 "za",
357 "gs",
358 "es",
359 "lk",
360 "sd",
361 "sr",
362 "sj",
363 "sz",
364 "se",
365 "ch",
366 "sy",
367 "tw",
368 "tj",
369 "tz",
370 "th",
371 "tl",
372 "tg",
373 "tk",
374 "to",
375 "tt",
376 "tn",
377 "tr",
378 "tm",
379 "tc",
380 "tv",
381 "ug",
382 "ua",
383 "ae",
384 "gb",
385 "us",
386 "um",
387 "uy",
388 "uz",
389 "vu",
390 "ve",
391 "vn",
392 "vg",
393 "vi",
394 "wf",
395 "eh",
396 "ye",
397 "zm",
398 "zw"
399 ],
400 "type": "string",
401 "description": "This param is for the Country (e.g. <code>es</code> for Spain). The values must be lower-cased <a href=\"https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2\" target=\"_blank\">ISO 3166</a> country codes supported by Google. By default, the actor uses United States (<code>us</code>).<br><br><b>Notice</b>: To get Google Shopping results from a location, please use UULE code. If you choose <code>countryCode</code> as <code>es</code> without setting <code>locationUule</code>, you will get the results from United States(default search location). To get results from Spain, you need to set <code>locationUule</code> to <code>w+CAIQICIFU3BhaW4=</code>"
402 },
403 "languageCode": {
404 "title": "Language",
405 "enum": [
406 "",
407 "af",
408 "sq",
409 "sm",
410 "ar",
411 "az",
412 "eu",
413 "be",
414 "bn",
415 "bh",
416 "bs",
417 "bg",
418 "ca",
419 "zh-CN",
420 "zh-TW",
421 "hr",
422 "cs",
423 "da",
424 "nl",
425 "en",
426 "eo",
427 "et",
428 "fo",
429 "fi",
430 "fr",
431 "fy",
432 "gl",
433 "ka",
434 "de",
435 "el",
436 "gu",
437 "iw",
438 "hi",
439 "hu",
440 "is",
441 "id",
442 "ia",
443 "ga",
444 "it",
445 "ja",
446 "jw",
447 "kn",
448 "ko",
449 "la",
450 "lv",
451 "lt",
452 "mk",
453 "ms",
454 "ml",
455 "mt",
456 "mr",
457 "ne",
458 "no",
459 "nn",
460 "oc",
461 "fa",
462 "pl",
463 "pt-BR",
464 "pt-PT",
465 "pa",
466 "ro",
467 "ru",
468 "gd",
469 "sr",
470 "si",
471 "sk",
472 "sl",
473 "es",
474 "su",
475 "sw",
476 "sv",
477 "tl",
478 "ta",
479 "te",
480 "th",
481 "ti",
482 "tr",
483 "uk",
484 "ur",
485 "uz",
486 "vi",
487 "cy",
488 "xh",
489 "zu"
490 ],
491 "type": "string",
492 "description": "Language for the search results, which is passed to Google Search as the <code>hl</code> URL query parameter. Only set this if you want to use a non-default language for the selected country. The values must be lower-cased <a href=\"https://en.wikipedia.org/wiki/List_of_ISO_639-1_codes\" target=\"_blank\">ISO 639</a> language codes supported by Google.",
493 "default": ""
494 },
495 "googleDomain": {
496 "title": "Google Domain",
497 "enum": [
498 "",
499 "google.ad",
500 "google.ae",
501 "google.com.af",
502 "google.com.ag",
503 "google.com.ai",
504 "google.al",
505 "google.am",
506 "google.co.ao",
507 "google.com.ar",
508 "google.as",
509 "google.at",
510 "google.com.au",
511 "google.az",
512 "google.ba",
513 "google.com.bd",
514 "google.be",
515 "google.bf",
516 "google.bg",
517 "google.com.bh",
518 "google.bi",
519 "google.bj",
520 "google.com.bn",
521 "google.com.bo",
522 "google.com.br",
523 "google.bs",
524 "google.bt",
525 "google.co.bw",
526 "google.by",
527 "google.com.bz",
528 "google.ca",
529 "google.com.kh",
530 "google.cd",
531 "google.cf",
532 "google.cg",
533 "google.ch",
534 "google.ci",
535 "google.co.ck",
536 "google.cl",
537 "google.cm",
538 "google.com.co",
539 "google.co.cr",
540 "google.com.cu",
541 "google.cv",
542 "google.com.cy",
543 "google.cz",
544 "google.de",
545 "google.dj",
546 "google.dk",
547 "google.dm",
548 "google.com.do",
549 "google.dz",
550 "google.com.ec",
551 "google.ee",
552 "google.com.eg",
553 "google.es",
554 "google.com.et",
555 "google.fi",
556 "google.fm",
557 "google.com.fj",
558 "google.fr",
559 "google.ga",
560 "google.ge",
561 "google.com.gh",
562 "google.com.gi",
563 "google.gl",
564 "google.gm",
565 "google.gp",
566 "google.gr",
567 "google.com.gt",
568 "google.gy",
569 "google.com.hk",
570 "google.hn",
571 "google.hr",
572 "google.ht",
573 "google.hu",
574 "google.co.id",
575 "google.iq",
576 "google.ie",
577 "google.co.il",
578 "google.co.in",
579 "google.is",
580 "google.it",
581 "google.je",
582 "google.com.jm",
583 "google.jo",
584 "google.co.jp",
585 "google.co.ke",
586 "google.ki",
587 "google.kg",
588 "google.co.kr",
589 "google.com.kw",
590 "google.kz",
591 "google.la",
592 "google.com.lb",
593 "google.li",
594 "google.lk",
595 "google.co.ls",
596 "google.lt",
597 "google.lu",
598 "google.lv",
599 "google.com.ly",
600 "google.co.ma",
601 "google.md",
602 "google.mg",
603 "google.mk",
604 "google.ml",
605 "google.com.mm",
606 "google.mn",
607 "google.ms",
608 "google.com.mt",
609 "google.mu",
610 "google.mv",
611 "google.mw",
612 "google.com.mx",
613 "google.com.my",
614 "google.co.mz",
615 "google.com.na",
616 "google.ne",
617 "google.com.ng",
618 "google.com.ni",
619 "google.nl",
620 "google.no",
621 "google.com.np",
622 "google.nr",
623 "google.nu",
624 "google.co.nz",
625 "google.com.om",
626 "google.com.pk",
627 "google.com.pa",
628 "google.com.pe",
629 "google.com.ph",
630 "google.pl",
631 "google.com.pg",
632 "google.com.pr",
633 "google.ps",
634 "google.pt",
635 "google.com.py",
636 "google.com.qa",
637 "google.ro",
638 "google.rs",
639 "google.ru",
640 "google.rw",
641 "google.com.sa",
642 "google.com.sb",
643 "google.sc",
644 "google.se",
645 "google.com.sg",
646 "google.sh",
647 "google.si",
648 "google.sk",
649 "google.com.sl",
650 "google.sn",
651 "google.sm",
652 "google.so",
653 "google.sr",
654 "google.com.sv",
655 "google.td",
656 "google.tg",
657 "google.co.th",
658 "google.com.tj",
659 "google.tk",
660 "google.tl",
661 "google.tm",
662 "google.to",
663 "google.tn",
664 "google.com.tr",
665 "google.tt",
666 "google.com.tw",
667 "google.co.tz",
668 "google.com.ua",
669 "google.co.ug",
670 "google.co.uk",
671 "google.com.uy",
672 "google.co.uz",
673 "google.com.vc",
674 "google.co.ve",
675 "google.vg",
676 "google.co.vi",
677 "google.com.vn",
678 "google.vu",
679 "google.ws",
680 "google.co.za",
681 "google.co.zm",
682 "google.co.zw"
683 ],
684 "type": "string",
685 "description": "This param is for the Google Search Domain (e.g. <code>google.es</code> for Spain). By default, the actor uses United States (<code>google.com</code>).</br><br><br><b>Notice</b>: To get Google Shopping results from a location, please use UULE code. If you choose <code>googleDomain</code> as <code>google.es</code> without setting <code>locationUule</code>, you will get the results from United States(default search location). To get results from Spain, you need to set <code>locationUule</code> to <code>w+CAIQICIFU3BhaW4=</code>"
686 },
687 "filterValue": {
688 "title": "Filter or sort results by categories",
689 "type": "string",
690 "description": "Input filterValue to filter Google Shopping results by price, band... The filterValue can be found in shopping results response. To apply multiple filters, you can try one filter first, then check the response and find the following filters."
691 },
692 "device": {
693 "title": "Device",
694 "enum": [
695 "desktop",
696 "mobile",
697 "tablet"
698 ],
699 "type": "string",
700 "description": "Device can be \"desktop\", \"mobile\" or \"tablet.",
701 "default": "desktop"
702 },
703 "csvFriendlyOutput": {
704 "title": "Output CSV friendly format",
705 "type": "boolean",
706 "description": "Include shopping results data, use for CSV format"
707 }
708 }
709 },
710 "runsResponseSchema": {
711 "type": "object",
712 "properties": {
713 "data": {
714 "type": "object",
715 "properties": {
716 "id": {
717 "type": "string"
718 },
719 "actId": {
720 "type": "string"
721 },
722 "userId": {
723 "type": "string"
724 },
725 "startedAt": {
726 "type": "string",
727 "format": "date-time",
728 "example": "2025-01-08T00:00:00.000Z"
729 },
730 "finishedAt": {
731 "type": "string",
732 "format": "date-time",
733 "example": "2025-01-08T00:00:00.000Z"
734 },
735 "status": {
736 "type": "string",
737 "example": "READY"
738 },
739 "meta": {
740 "type": "object",
741 "properties": {
742 "origin": {
743 "type": "string",
744 "example": "API"
745 },
746 "userAgent": {
747 "type": "string"
748 }
749 }
750 },
751 "stats": {
752 "type": "object",
753 "properties": {
754 "inputBodyLen": {
755 "type": "integer",
756 "example": 2000
757 },
758 "rebootCount": {
759 "type": "integer",
760 "example": 0
761 },
762 "restartCount": {
763 "type": "integer",
764 "example": 0
765 },
766 "resurrectCount": {
767 "type": "integer",
768 "example": 0
769 },
770 "computeUnits": {
771 "type": "integer",
772 "example": 0
773 }
774 }
775 },
776 "options": {
777 "type": "object",
778 "properties": {
779 "build": {
780 "type": "string",
781 "example": "latest"
782 },
783 "timeoutSecs": {
784 "type": "integer",
785 "example": 300
786 },
787 "memoryMbytes": {
788 "type": "integer",
789 "example": 1024
790 },
791 "diskMbytes": {
792 "type": "integer",
793 "example": 2048
794 }
795 }
796 },
797 "buildId": {
798 "type": "string"
799 },
800 "defaultKeyValueStoreId": {
801 "type": "string"
802 },
803 "defaultDatasetId": {
804 "type": "string"
805 },
806 "defaultRequestQueueId": {
807 "type": "string"
808 },
809 "buildNumber": {
810 "type": "string",
811 "example": "1.0.0"
812 },
813 "containerUrl": {
814 "type": "string"
815 },
816 "usage": {
817 "type": "object",
818 "properties": {
819 "ACTOR_COMPUTE_UNITS": {
820 "type": "integer",
821 "example": 0
822 },
823 "DATASET_READS": {
824 "type": "integer",
825 "example": 0
826 },
827 "DATASET_WRITES": {
828 "type": "integer",
829 "example": 0
830 },
831 "KEY_VALUE_STORE_READS": {
832 "type": "integer",
833 "example": 0
834 },
835 "KEY_VALUE_STORE_WRITES": {
836 "type": "integer",
837 "example": 1
838 },
839 "KEY_VALUE_STORE_LISTS": {
840 "type": "integer",
841 "example": 0
842 },
843 "REQUEST_QUEUE_READS": {
844 "type": "integer",
845 "example": 0
846 },
847 "REQUEST_QUEUE_WRITES": {
848 "type": "integer",
849 "example": 0
850 },
851 "DATA_TRANSFER_INTERNAL_GBYTES": {
852 "type": "integer",
853 "example": 0
854 },
855 "DATA_TRANSFER_EXTERNAL_GBYTES": {
856 "type": "integer",
857 "example": 0
858 },
859 "PROXY_RESIDENTIAL_TRANSFER_GBYTES": {
860 "type": "integer",
861 "example": 0
862 },
863 "PROXY_SERPS": {
864 "type": "integer",
865 "example": 0
866 }
867 }
868 },
869 "usageTotalUsd": {
870 "type": "number",
871 "example": 0.00005
872 },
873 "usageUsd": {
874 "type": "object",
875 "properties": {
876 "ACTOR_COMPUTE_UNITS": {
877 "type": "integer",
878 "example": 0
879 },
880 "DATASET_READS": {
881 "type": "integer",
882 "example": 0
883 },
884 "DATASET_WRITES": {
885 "type": "integer",
886 "example": 0
887 },
888 "KEY_VALUE_STORE_READS": {
889 "type": "integer",
890 "example": 0
891 },
892 "KEY_VALUE_STORE_WRITES": {
893 "type": "number",
894 "example": 0.00005
895 },
896 "KEY_VALUE_STORE_LISTS": {
897 "type": "integer",
898 "example": 0
899 },
900 "REQUEST_QUEUE_READS": {
901 "type": "integer",
902 "example": 0
903 },
904 "REQUEST_QUEUE_WRITES": {
905 "type": "integer",
906 "example": 0
907 },
908 "DATA_TRANSFER_INTERNAL_GBYTES": {
909 "type": "integer",
910 "example": 0
911 },
912 "DATA_TRANSFER_EXTERNAL_GBYTES": {
913 "type": "integer",
914 "example": 0
915 },
916 "PROXY_RESIDENTIAL_TRANSFER_GBYTES": {
917 "type": "integer",
918 "example": 0
919 },
920 "PROXY_SERPS": {
921 "type": "integer",
922 "example": 0
923 }
924 }
925 }
926 }
927 }
928 }
929 }
930 }
931 }
932}
Google Shopping 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 Google Shopping 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:
Pricing
Pricing model
Pay per eventThis Actor is paid per result. You are not charged for the Apify platform usage, but only a fixed price for each dataset of 1,000 items in the Actor outputs.
One Page
$0.040
1 page contains 40 results. 1000 results = 25 pages costs only 1 USD