Browse 800+ Public APIs

How to Scrap Google Search Data in Nodejs

a year ago

Scraping Google search results can be a valuable technique for various purposes such as market research, SEO analysis, and content aggregation. In this tutorial, we'll explore how to scrape Google search results data using Node.js.

Why scrape search results?

There are several reasons why scraping Google search results can be beneficial:

  • Market Research: Analyzing search results can provide insights into trends, customer preferences, and competitors' strategies.
  • SEO Analysis: Scraping search results helps in understanding keyword rankings, SERP features, and overall SEO performance.
  • Content Aggregation: Gathering data from search results can aid in content creation, topic discovery, and identifying gaps in existing content.

Now, let's dive into the process of scraping Google search results using Node.js and the Zenserp API.

  1. Sign up for a free Zenserp account: Access the API without providing any credit card information and receive an API key for authentication.

ā†’ Get your API key here

  1. Locate your API key: Once logged in, navigate to your dashboard to find your API key. This key will be essential for authenticating your requests.

Zenserp Key

  1. Create your Node.js project: Initialize a new project using npm or yarn:
npm init -y
const axios = require('axios');

async function scrapeGoogleSearch(query) {
    const apiKey = 'YOUR_ZENSERP_API_KEY';
    const apiUrl = `https://app.zenserp.com/api/v2/search?q=${query}&apiKey=${apiKey}`;

    try {
        const response = await axios.get(apiUrl);
        const searchResults = response.data;

        // Process search results
        console.log(searchResults);
    } catch (error) {
        console.error('Error scraping Google search:', error);
    }
}

// Example usage
const searchQuery = 'Your search query';
scrapeGoogleSearch(searchQuery);

Replace 'YOUR_ZENSERP_API_KEY' with your actual API key obtained from Zenserp. This code sends a request to the Zenserp API with the specified search query and retrieves the search results in JSON format. You can then process the results according to your requirements.

{
	"organic": [
		{
			"position": 1,
			"title": "Pied Piper of Hamelin - Wikipedia",
			"url": "https://en.wikipedia.org/wiki/Pied_Piper_of_Hamelin",
			"destination": "https://en.wikipedia.org/wiki/Pied_Piper_of_Hamelin",
			"description": "The Pied Piper of Hamelin is the titular character of..."
		},
        ...
    ]
}

This response contains an array of organic search results, each represented as an object with the following properties:

  • position: The position of the search result in the search engine results page (SERP).
  • title: The title of the search result.
  • url: The URL of the search result.
  • destination: The destination URL of the search result.
  • description: A brief description of the search result.
  • isAmp: A boolean indicating whether the search result is an AMP (Accelerated Mobile Pages) page.

You can use this information to process and display search results in your application or perform further analysis as needed.

Remember to handle errors gracefully and adhere to the terms of service of both Google and the scraping tool or service you use.

That's it! You now have a basic understanding of how to scrape Google search results data using Node.js and the Zenserp API. Happy scraping!