Scraping Google News
Free Google News Scraper
Prerequisites
To run this tool, you need to have Python 3.11 installed in your system.
Installation
Open up a terminal window, navigate to this repository and run this command:
make install
Getting the topic to scrape
This tool is used to scrape Google News articles based on the topic they're listed in.
First of all, open up Google News, and look through the topics listed in the top header of the webpage.
Click on a topic you wish to scrape.
In this example we'll be using the Business
topic.
Next, look at the URL in your browser and copy the string of characters that come after /topics/
, that's your topic ID.
In the URL shown in the screenshot, the topic ID would be CAAqJggKIiBDQkFTRWdvSUwyMHZNRGx6TVdZU0FtVnVHZ0pWVXlnQVAB
.
Save this value, you'll need it for scraping the articles.
Scraping
To scrape articles from your selected topic, run this command in your terminal:
make scrape TOPIC_ID=<your_selected_topic_id>
With the Business
topic ID selected before, the command should look like this:
make scrape TOPIC_ID=CAAqJggKIiBDQkFTRWdvSUwyMHZNRGx6TVdZU0FtVnVHZ0pWVXlnQVAB
After running the command, you should see this in your terminal:
When the tool has finished running, you should see a file named articles.csv
in the directory you were running the tool.
If you open the generated CSV file, the data should look something like this:
Notes
In case the code doesn't work or your project is of bigger scale, please refer to the second part of the tutorial. There, we showcase how to scrape public data with Oxylabs Scraper API.
Oxylabs Google News API
You can get a 7-day trial for Oxylabs Google News API and get free 5K results. The tool will deliver a list of sources, titles, URLs, and dates from published articles all over the Google News portal. This API returns real-time data and gives access to localized results, all while avoiding blocks.
After you claim your trial, using Google News API consists of three main steps:
- Create your API user via our dashboard
- Send a request
- Retrieve the data in JSON or HTML
Request sample
In the example below, we use Google News API and make a request to collect search result pages for the search term adidas
on the google.nl
domain:
import requests
from pprint import pprint
# Structure payload.
payload = {
'source': 'google_search',
'domain': 'nl',`
'query': 'adidas',
'parse': True,
'context': [
{'key': 'tbm', 'value': 'nws'},
],
}
# Get response.
response = requests.post(
'https://realtime.oxylabs.io/v1/queries',
auth=('USERNAME', 'PASSWORD'),
json=payload,
)
# Print prettified response to stdout.
pprint(response.json())
To see request samples in other languages and parameter values along with their descriptions, please take a look at our extensive Google News API documentation.
Read More Google Scraping Related Repositories: Google Sheets for Basic Web Scraping, How to Scrape Google Shopping Results, Google Play Scraper, How To Scrape Google Jobs, How to Scrape Google Scholar, How to Scrape Google Flights with Python, How To Scrape Google Images, Scrape Google Search Results, Scrape Google Trends