Google Search Parser
Using the ScrapeOps Parser API you can scrape Google Search Pages without having to maintain your own product parsers.
Simply send the HTML of the Google Search Pages to the Parser API endpoint, and receive the data in structured JSON format.
Google Search Parser API Endpoint:
"https://parser.scrapeops.io/v2/google"
The Google Search Parser supports the following page types:
- Google Search Pages
- Google Image Search Pages
- Google Video Search Pages
- Google News Search Pages
- Google Shop Search Pages
Authorisation - API Key
To use the ScrapeOps Parser API, you first need an API key which you can get by signing up for a free account here.
Your API key must be included with every request using the api_key query parameter otherwise the API will return a 403 Forbidden Access status code.

Google Search Page Parser
To use the Parser API without the ScrapeOps Proxy Aggregator, you first need to retrieve the HTML of the page you want to extract the data from.
For example, here we retrieve the HTML from the following Google Search Page with a very simple GET request:
import requests
response = requests.get('https://www.google.com/search?q=scrapeops')
if response.status_code == 200:
html = response.text
print(html)
Next, we send this HTML to the ScrapeOps Parser API for data extraction using a POST request:
import requests
response = requests.get('https://www.google.com/search?q=scrapeops')
if response.status_code == 200:
html = response.text
data = {
'url': 'https://www.google.com/search?q=scrapeops',
'html': html,
}
response = requests.post(
url='https://parser.scrapeops.io/v2/google',
params={'api_key': 'YOUR_API_KEY'},
json=data
)
print(response.json())
The API will return a JSON response with the following data (status, data, url):
{
"data": {
"ads": [
{
"position": 1,
"block_position": "bottom",
"title": "All Proxy Providers | From $9 | Use 20 Proxy Providers From $9",
"link": "https://scrapeops.io/proxy-aggregator/",
"thumbnail": "",
"displayed_link": "https://www.scrapeops.io",
"tracking_link": "https://www.googleadservices.com/pagead/aclk?sa=L&ai=DChcSEwjC0cLtmaOIAxXXW0cBHc4oILAYABAAGgJxdQ&co=1&ase=2&gclid=EAIaIQobChMIwtHC7ZmjiAMV11tHAR3OKCCwEAMYASAAEgLDr_D_BwE&ohost=www.google.com&cid=CAASJeRoXbuQyf4BkBeQAX2gsqHzgKyPv65KsQZhFgcKWbaXO5zrtBk&sig=AOD64_3LVxBTF--HLLgsKwuo62R95euAeQ&q&nis=4&adurl",
"description": "Use +20 proxy providers with 1 proxy API. Best reliability and cheapest rates guaranteed. No more searching for proxies. Use +20 proxy providers with 1 proxy API. From $9 month. Free Trial. 1,000 Free API Credits.",
"sitelinks": {
"inline": [
{
"title": "Best Free Proxies",
"url": "https://scrapeops.io/proxy-providers/comparison/free-proxy-providers"
},
{
"title": "Residential Proxies",
"url": "https://scrapeops.io/proxy-providers/comparison/best-residential-proxies"
}
...
],
"block": null
}
},
{
"position": 2,
"block_position": "bottom",
"title": "Try SOAX's Proxy Network | Scrapingbee",
"link": "https://soax.com/scraping",
"thumbnail": "",
"displayed_link": "https://www.soax.com › scraping",
"tracking_link": "https://www.googleadservices.com/pagead/aclk?sa=L&ai=DChcSEwjC0cLtmaOIAxXXW0cBHc4oILAYABABGgJxdQ&co=1&ase=2&gclid=EAIaIQobChMIwtHC7ZmjiAMV11tHAR3OKCCwEAMYAiAAEgJROvD_BwE&ohost=www.google.com&cid=CAASJeRoXbuQyf4BkBeQAX2gsqHzgKyPv65KsQZhFgcKWbaXO5zrtBk&sig=AOD64_31YTQ8hGnD720TNdzWQEzMBndlgQ&q&nis=4&adurl",
"description": "Turn websites into structured data and collect public data effortlessly with a simple API. Companies around the world use our wide pool of legitimate and stable IPv6/IPv4...",
"sitelinks": {
"inline": null,
"block": null
}
}
...
],
"related_questions": [
{
"question": "Is ScrapeOps free?"
}
...
],
"related_searches": [
{
"text": "ScrapeOps pricing",
"url": "https://www.google.com/search?sca_esv=0568c64b8556c91d&q=ScrapeOps+pricing&sa=X&ved=2ahUKEwiKhr7tmaOIAxVdElkFHTv4MbIQ1QJ6BAhREAE"
},
{
"text": "Scrapeops proxy",
"url": "https://www.google.com/search?sca_esv=0568c64b8556c91d&q=Scrapeops+proxy&sa=X&ved=2ahUKEwiKhr7tmaOIAxVdElkFHTv4MbIQ1QJ6BAhOEAE"
}
...
],
"search_information": {
"query": "scrapeops",
"time_taken_displayed": 0.24,
"total_results": 5260
},
"search_results": [
{
"position": 1,
"title": "ScrapeOps - The DevOps Tool For Web Scraping. | ScrapeOps",
"snippet": "ScrapeOps is a devops tool for web scraping which enables you to easily monitor, analyse and schedule your scraping jobs.",
"link": "https://scrapeops.io/",
"date": "",
"displayed_link": "https://scrapeops.io",
"thumbnail": "",
"site_links": {
"inline": null,
"block": [
{
"snippet": "Menu. Login. Email *. Password *. Login. Forgot your password ...",
"title": "Login",
"url": "https://scrapeops.io/app/login"
},
{
"snippet": "Everything you need to know about Scrapy, its pros and cons ...",
"title": "The Python Scrapy Playbook",
"url": "https://scrapeops.io/python-scrapy-playbook/"
}
...
]
}
},
{
"position": 2,
"title": "ScrapeOps",
"snippet": "ScrapeOps is the job monitoring and managing tool for web scrapers. Schedule your scraping jobs, monitor their performance, get alerts and compare proxies!",
"link": "https://github.com/ScrapeOps",
"date": "",
"displayed_link": "https://github.com › ScrapeOps",
"thumbnail": "",
"site_links": {
"inline": null,
"block": null
}
}
...
]
},
"status": "parse_successful",
"url": "https://www.google.com/search?q=scrapeops&ec=futura_gmv_dt_so_72586115_e"
}
A full example JSON response can be found here.

Google Image Search Page Parser
To use the Parser API without the ScrapeOps Proxy Aggregator, you first need to retrieve the HTML of the page you want to extract the data from.
For example, here we retrieve the HTML from the following Google Image Search Page with a very simple GET request:
import requests
response = requests.get('https://www.google.com/search?q=scrapeops&udm=2')
if response.status_code == 200:
html = response.text
print(html)
Next, we send this HTML to the ScrapeOps Parser API for data extraction using a POST request:
import requests
response = requests.get('https://www.google.com/search?q=scrapeops&udm=2')
if response.status_code == 200:
html = response.text
data = {
'url': 'https://www.google.com/search?q=scrapeops&udm=2',
'html': html,
}
response = requests.post(
url='https://parser.scrapeops.io/v2/google',
params={'api_key': 'YOUR_API_KEY'},
json=data
)
print(response.json())
The API will return a JSON response with the following data (status, data, url):
{
"data": {
"related_searches": [
{
"text": "etl job monitoring dashboard",
"url": "https://www.google.com/search?sca_esv=d4df4a45296c77b3&udm=2&q=etl+job+monitoring+dashboard&stick=H4sIAAAAAAAAAFvEKpNakqOQlZ-kkJufl1mSX5SZl66QklickZSfWJQCAHw5wfAfAAAA&source=univ&sa=X&ved=2ahUKEwjf5_q-q6OIAxVGEFkFHcMhGQoQrNwCegQIcBAA"
},
{
"text": "web scraping",
"url": "https://www.google.com/search?sca_esv=d4df4a45296c77b3&udm=2&q=web+scraping&stick=H4sIAAAAAAAAAFvEylOemqRQnFyUWJCZlw4A938U_w8AAAA&source=univ&sa=X&ved=2ahUKEwjf5_q-q6OIAxVGEFkFHcMhGQoQrNwCegQIeBAA"
}
...
],
"related_topics": [
{
"image": "",
"text": "Webcatalog desktop",
"url": "https://www.google.com/search?sca_esv=d4df4a45296c77b3&q=webcatalog+desktop+scrapeops&uds=ADvngMiBw_HcYg9ZjlZrsyuTog__yVSP33gJ7dSW7pK-BJMPUnuX-eQ28EXa2lhJNsXDL_OHOZvmbkPc71rJYhsiUzmN2lyrR6RE09GSjMqPcwZ9t7yJDZ3PjLkXgep4tfj1oosFDeN5&udm=2&sa=X&ved=2ahUKEwjf5_q-q6OIAxVGEFkFHcMhGQoQxKsJegQIDRAB&ictx=0"
},
{
"image": "",
"text": "Axios",
"url": "https://www.google.com/search?sca_esv=d4df4a45296c77b3&q=axios+scrapeops&uds=ADvngMhWLxdD0hqgqE9I5Yd4cUhit5YwfjISIDMtSii92PmuVK_F5mpZBLHzK70bJCDZ6fXyWtWOkmGtggYfIAiS1MZOablxqJdUEqgeendBAxo7YdN3tANyUbp2GB3IQ-SY0K_tqMDp&udm=2&sa=X&ved=2ahUKEwjf5_q-q6OIAxVGEFkFHcMhGQoQxKsJegQICBAB&ictx=0"
}
...
],
"search_information": {
"query": "scrapeops"
},
"search_results": [
{
"icon": "\\x3d\\x3d",
"image": "...",
"source": "GitHub",
"title": "ScrapeOps · GitHub",
"url": "https://github.com/ScrapeOps"
},
{
"icon": "",
"image": "...",
"source": "scrapeops.io",
"title": "DevOps Tool For Web Scraping. | ScrapeOps",
"url": "https://scrapeops.io/"
}
...
]
},
"status": "parse_successful",
"url": "https://www.google.com/search?q=scrapeops&udm=2&ec=futura_gmv_dt_so_72586115_e"
}
A full example JSON response can be found here.

Google Video Search Page Parser
To use the Parser API without the ScrapeOps Proxy Aggregator, you first need to retrieve the HTML of the page you want to extract the data from.
For example, here we retrieve the HTML from the following Google Video Search Page with a very simple GET request:
import requests
response = requests.get('https://www.google.com/search?q=mongodb&tbm=vid')
if response.status_code == 200:
html = response.text
print(html)
Next, we send this HTML to the ScrapeOps Parser API for data extraction using a POST request:
import requests
response = requests.get('https://www.google.com/search?q=mongodb&tbm=vid')
if response.status_code == 200:
html = response.text
data = {
'url': 'https://www.google.com/search?q=mongodb&tbm=vid',
'html': html,
}
response = requests.post(
url='https://parser.scrapeops.io/v2/google',
params={'api_key': 'YOUR_API_KEY'},
json=data
)
print(response.json())
The API will return a JSON response with the following data (status, data, url):
{
"data": {
"pagination": [
{
"page": 1,
"selected": true
},
{
"link": "/search?q=mongodb&sca_esv=b3eb3acadfa7d029&tbm=vid&ei=pW3WZoj-Hu7e2roP0LmeqQc&start=10&sa=N&ved=2ahUKEwjI5MrU1qWIAxVur1YBHdCcJ3UQ8tMDegQIGBAE",
"page": 2
},
{
"link": "/search?q=mongodb&sca_esv=b3eb3acadfa7d029&tbm=vid&ei=pW3WZoj-Hu7e2roP0LmeqQc&start=20&sa=N&ved=2ahUKEwjI5MrU1qWIAxVur1YBHdCcJ3UQ8tMDegQIGBAG",
"page": 3
}
...
],
"related_searches": [
{
"link": "https://www.google.com/search?sca_esv=b3eb3acadfa7d029&tbm=vid&q=MongoDB+Crash+course&sa=X&ved=2ahUKEwjI5MrU1qWIAxVur1YBHdCcJ3UQ1QJ6BAgWEAE",
"text": "mongodb crash course"
},
{
"link": "https://www.google.com/search?sca_esv=b3eb3acadfa7d029&tbm=vid&q=MongoDB+videos&sa=X&ved=2ahUKEwjI5MrU1qWIAxVur1YBHdCcJ3UQ1QJ6BAgVEAE",
"text": "mongodb videos"
}
...
],
"search_information": {
"query": "mongodb",
"time_seconds": 0.49,
"total_results": 1160000
},
"search_results": [
{
"key_moment_count": 7,
"link": "https://www.youtube.com/watch?v=VOLeKvNz-Zo",
"site": "www.youtube.com› watch",
"snippet": "Learn more about MongoDB → http://ibm.biz/mongodb -guide Check out IBM Cloud Databases for MongoDB ...",
"source": "YouTube",
"thumbnail": "...",
"title": "What is MongoDB?",
"upload_date": "Aug 25, 2021",
"uploader": "IBM Technology",
"video_length": "5:39"
},
{
"key_moment_count": 7,
"link": "https://www.youtube.com/watch?v=ofme2o29ngU",
"site": "www.youtube.com› watch",
"snippet": "MongoDB Cheat Sheet: https://webdevsimplified.com/mongodb -cheat-sheet.html MongoDB is a complex NoSQL database with a ton of commands and ...",
"source": "YouTube",
"thumbnail": "...",
"title": "MongoDB Crash Course",
"upload_date": "Sep 29, 2021",
"uploader": "Web Dev Simplified",
"video_length": "29:59"
}
...
]
},
"status": "parse_successful",
"url": "https://www.google.com/search?q=mongodb&sca_esv=b3eb3acadfa7d029&tbm=vid&ei=QGvWZrG9Mryt0-kPqOeYoQE&ved=0ahUKEwix3bew1KWIAxW81jQHHagzJhQQ4dUDCA0&uact=5&oq=mongodb&gs_lp=Eg1nd3Mtd2l6LXZpZGVvIgdtb25nb2RiMgsQABiABBiRAhiKBTIFEAAYgAQyBRAAGIAEMgUQABiABDIFEAAYgAQyBRAAGIAEMgUQABiABDIFEAAYgAQyBRAAGIAEMgsQABiABBiGAxiKBUjuXVDLRFjyW3AAeACQAQCYAbwEoAGUFKoBBzMtNi4wLjG4AQPIAQD4AQGYAgegArEUwgIIEAAYgAQYogSYAwCIBgGSBwUzLTYuMaAHxSE&sclient=gws-wiz-video&ec=futura_gmv_dt_so_72586115_e"
}
A full example JSON response can be found here.

Google News Search Page Parser
To use the Parser API without the ScrapeOps Proxy Aggregator, you first need to retrieve the HTML of the page you want to extract the data from.
For example, here we retrieve the HTML from the following Google News Search Page with a very simple GET request:
import requests
response = requests.get('https://www.google.co.uk/search?q=earthquake&tbm=nws')
if response.status_code == 200:
html = response.text
print(html)
Next, we send this HTML to the ScrapeOps Parser API for data extraction using a POST request:
import requests
response = requests.get('https://www.google.co.uk/search?q=earthquake&tbm=nws')
if response.status_code == 200:
html = response.text
data = {
'url': 'https://www.google.co.uk/search?q=earthquake&tbm=nws',
'html': html,
}
response = requests.post(
url='https://parser.scrapeops.io/v2/google',
params={'api_key': 'YOUR_API_KEY'},
json=data
)
print(response.json())
The API will return a JSON response with the following data (status, data, url):
{
"data": {
"pagination": [
{
"number": 1,
"selected": true
},
{
"number": 2,
"url": "/search?q=mongodb&sca_esv=7d26b11aab597cbb&tbm=nws&ei=kZ7XZsHZEtLT2roPpLaKsA4&start=10&sa=N&ved=2ahUKEwiB5rK6-aeIAxXSqVYBHSSbAuYQ8tMDegQIAhAE"
}
...
],
"search_information": {
"query": "mongodb",
"time_seconds": 0.14,
"total_results": 12300
},
"search_results": [
{
"date": "6 hours ago",
"snippet": "From idea to IPO, Disrupt charts startups at every stage on the roadmap to their next breakthrough. TechCrunch will gather some of the...",
"source": "TechCrunch",
"source_icon": "...",
"thumbnail": "...",
"title": "Learn startup best practices with MongoDB, Venture Backed, InterSystems and others at Disrupt 2024",
"url": "https://techcrunch.com/2024/09/03/learn-startup-best-practices-with-mongodb-venture-backed-intersystems-and-others-at-disrupt-2024/"
},
{
"date": "3 days ago",
"snippet": "MongoDB's Q2 results crushed expectations across the board. Here's why the stock still has room to grow despite a lofty valuation.",
"source": "Yahoo Finance",
"source_icon": "...",
"thumbnail": "...",
"title": "MongoDB Defies Doubters With Strong Q2 Performance",
"url": "https://finance.yahoo.com/news/mongodb-defies-doubters-strong-q2-155100980.html"
}
...
]
},
"status": "parse_successful",
"url": "https://www.google.com/search?q=mongodb&tbm=nws&ec=futura_gmv_dt_so_72586115_e"
}
A full example JSON response can be found here.

Google Shop Search Page Parser
To use the Parser API without the ScrapeOps Proxy Aggregator, you first need to retrieve the HTML of the page you want to extract the data from.
For example, here we retrieve the HTML from the following Google Shop Search Page with a very simple GET request:
import requests
response = requests.get('https://www.google.com/search?q=bag&hl=en&udm=28')
if response.status_code == 200:
html = response.text
print(html)
Next, we send this HTML to the ScrapeOps Parser API for data extraction using a POST request:
import requests
response = requests.get('https://www.google.com/search?q=bag&hl=en&udm=28')
if response.status_code == 200:
html = response.text
data = {
'url': 'https://www.google.com/search?q=bag&hl=en&udm=28',
'html': html,
}
response = requests.post(
url='https://parser.scrapeops.io/v2/google',
params={'api_key': 'YOUR_API_KEY'},
json=data
)
print(response.json())
The API will return a JSON response with the following data (status, data, url):
{
"data": {
"ads": [
{
"domain": "timbuk2.com",
"fulfillments": [
"Free shipping",
"30-day return policy"
],
"image": "https://encrypted-tbn1.gstatic.com/shopping?q=tbn:ANd9GcQmhS6Kc8_Itz4xNHbD1dy7LhHzkLjjSHRRf9ecHvJDaADc5dTrzcGj4Y1CKfFkxK7FYw2pEd6Hal0kcCviGeruKm8II36ohpF3i8sJTVeyDF7BqbDGzhLXwXYDMMFL7e1awXjTvos&usqp=CAc",
"name": "Timbuk2 Classic Messenger Bag, Gunmetal, X-Small",
"price": 99,
"price_string": "$99.00",
"rating_star": 4.6,
"reviews_count": "2k+",
"source": "Timbuk2",
"url": "https://www.timbuk2.com/products/2023-classic-messenger-bag?variant=40578607448106¤cy=USD"
},
{
"domain": "silkletter.com",
"fulfillments": [
"30-day returns (most)"
],
"image": "https://encrypted-tbn2.gstatic.com/shopping?q=tbn:ANd9GcQ00cVPHZyNe47el4hAMZztuM1-Mf3Pj7KyOJSMOW4BX5IV2TfFp--uXhK49NzMCAnlov7OxYYcnDdmTqWInIbWBDYWeATQ7FDqCqUGmaRH1TVoQ6Cjfpq9rKcHwss_wRvowgeZhXE&usqp=CAc",
"name": "Custom Backpacks, Custom Printed Promotional, 600D Polyester, Blank Sample",
"price": 6.69,
"price_string": "$6.69",
"source": "SilkLetter",
"url": "https://silkletter.com/school-backpacks.html"
}
...
],
"search_results": [
{
"delivery": "Free $100+",
"image": "https://encrypted-tbn2.gstatic.com/shopping?q=tbn:ANd9GcTCALGBufmmSDeEjNllCKHqvNBPC8xIvlfggnlNM2uHneRai3_K4HmmvJSDYfSdUnPy2pvyjWtnMDw5MYkxsJIgRmJGKBBFX2QwoMPN-qX-mEKN4JBVOM8zSg",
"name": "Charles &Keith Women's Kora Metallic-Accent Moon Bag",
"price": 83,
"price_string": "$83.00",
"rating_star": 4,
"reviews_count": "1",
"source": "charleskeith.com"
},
{
"delivery": "Free by 9/16",
"image": "https://encrypted-tbn0.gstatic.com/shopping?q=tbn:ANd9GcSotxw8VjkExeswXn9am4-UJXGAR3_aLDG3bH7Tu0BrHxkdSR_Iv0JT9nPtNsqNaJFXwW3bJtYnXYG7tjp--HYQ2oX1mdFdUNPYa2rFxsI",
"name": "Michael Kors Bags Michael Kors Xs Jet Set Travel Womens Carryall Top Zip Tote",
"price": 79,
"price_savings": "82% OFF",
"price_string": "$79.00",
"price_was": "$448",
"rating_star": 4.6,
"reviews_count": "535",
"source": "Michael Kors"
}
...
]
},
"status": "parse_successful",
"url": "https://www.google.com/search?q=bag&sca_esv=41706f494ee2e9ff&hl=en&udm=28&psb=1&ei=YiDXZoW-DezMkPIP1KnkgQw&ved=0ahUKEwiF94qPgaeIAxVsJkQIHdQUOcAQ4dUDCCA&uact=5&oq=bag&gs_lp=Egxnd3Mtd2l6LXNlcnAiA2JhZzIKEAAYsAMY1gQYRzIKEAAYsAMY1gQYRzIKEAAYsAMY1gQYRzIKEAAYsAMY1gQYRzIKEAAYsAMY1gQYRzIKEAAYsAMY1gQYRzIKEAAYsAMY1gQYRzIKEAAYsAMY1gQYR0iqFVCcClieE3ACeACQAQCYAQCgAQCqAQC4AQPIAQD4AQGYAgKgAgaYAwCIBgGQBgiSBwEyoAcA&sclient=gws-wiz-serp&ec=futura_gmv_dt_so_72586115_e"
}
A full example JSON response can be found here.
Proxy API Integration
The ScrapeOps Parser API is integrated into the ScrapeOps Proxy API Aggregator and can be used for free by using the Auto Extract functionality.
So if you already have a Proxy API Aggregator plan then use the Parser API for no extra charge.
The following example shows you how to use the Parser API via a Python Requests based scraper using the Proxy API Aggregator:
import requests
response = requests.get(
url='https://proxy.scrapeops.io/v1/',
params={
'api_key': 'YOUR_API_KEY',
'url': 'https://www.google.com/search?q=scrapeops',
'auto_extract': 'google'
}
)
print(response.json())