google-news

Google News is a free news aggregator by Google that surfaces headlines from thousands of publishers worldwide. Use this skill to fetch top stories, topic feeds, location-specific news, and keyword searches via the public Google News RSS feeds. No API key or authentication is required.

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "google-news" with this command: npx skills add outsharp/shipp-skills/outsharp-shipp-skills-google-news

Google News RSS API

Google News is a free news aggregator that collects headlines from thousands of publishers around the world. Google exposes its feeds via public RSS 2.0 endpoints that require no authentication or API key.


Base URL

https://news.google.com/rss

All feed URLs are built by appending paths and query parameters to this base.


Query Parameters

Every feed URL accepts the following query parameters to control region and language:

ParameterRequiredDescriptionExample
hlYesInterface language / locale codeen-US, fr, de, ja, pt-BR, es-419
glYesCountry / geographic location (ISO 3166-1 alpha-2)US, GB, IN, DE, JP, BR
ceidYesCompound locale key in the form {gl}:{language}US:en, GB:en, DE:de, JP:ja, BR:pt-419

Important: All three parameters should be consistent. Mismatched values may return unexpected or empty results.


Supported Locations (Validated)

The following locations have been tested and confirmed to return valid RSS feeds (HTTP 200):

LocationhlglceidExample URL
🇺🇸 United Statesen-USUSUS:enhttps://news.google.com/rss?hl=en-US&gl=US&ceid=US:en
🇬🇧 United Kingdomen-GBGBGB:enhttps://news.google.com/rss?hl=en-GB&gl=GB&ceid=GB:en
🇮🇳 Indiaen-INININ:enhttps://news.google.com/rss?hl=en-IN&gl=IN&ceid=IN:en
🇦🇺 Australiaen-AUAUAU:enhttps://news.google.com/rss?hl=en-AU&gl=AU&ceid=AU:en
🇨🇦 Canadaen-CACACA:enhttps://news.google.com/rss?hl=en-CA&gl=CA&ceid=CA:en
🇩🇪 GermanydeDEDE:dehttps://news.google.com/rss?hl=de&gl=DE&ceid=DE:de
🇫🇷 FrancefrFRFR:frhttps://news.google.com/rss?hl=fr&gl=FR&ceid=FR:fr
🇯🇵 JapanjaJPJP:jahttps://news.google.com/rss?hl=ja&gl=JP&ceid=JP:ja
🇧🇷 Brazilpt-BRBRBR:pt-419https://news.google.com/rss?hl=pt-BR&gl=BR&ceid=BR:pt-419
🇲🇽 Mexicoes-419MXMX:es-419https://news.google.com/rss?hl=es-419&gl=MX&ceid=MX:es-419
🇮🇱 Israelen-ILILIL:enhttps://news.google.com/rss?hl=en-IL&gl=IL&ceid=IL:en

Feed Types

1. Top Stories (Headlines)

Returns the current top stories for a given location.

URL pattern:

https://news.google.com/rss?hl={hl}&gl={gl}&ceid={gl}:{lang}

Example — US top stories:

https://news.google.com/rss?hl=en-US&gl=US&ceid=US:en

2. Topic Feeds

Returns articles for a specific news topic / section.

URL pattern:

https://news.google.com/rss/topics/{TOPIC_ID}?hl={hl}&gl={gl}&ceid={gl}:{lang}

Known Topic IDs (English, US):

TopicTopic ID
WorldCAAqJggKIiBDQkFTRWdvSUwyMHZNRGx1YlY4U0FtVnVHZ0pWVXlnQVAB
Nation / U.S.CAAqIggKIhxDQkFTRHdvSkwyMHZNRGxqTjNjU0FtVnVLQUFQAQ
BusinessCAAqJggKIiBDQkFTRWdvSUwyMHZNRGx6TVdZU0FtVnVHZ0pWVXlnQVAB
TechnologyCAAqJggKIiBDQkFTRWdvSUwyMHZNRGRqTVhZU0FtVnVHZ0pWVXlnQVAB
EntertainmentCAAqJggKIiBDQkFTRWdvSUwyMHZNREpxYW5RU0FtVnVHZ0pWVXlnQVAB
SportsCAAqJggKIiBDQkFTRWdvSUwyMHZNRFp1ZEdvU0FtVnVHZ0pWVXlnQVAB
ScienceCAAqJggKIiBDQkFTRWdvSUwyMHZNRFp0Y1RjU0FtVnVHZ0pWVXlnQVAB
HealthCAAqIQgKIhtDQkFTRGdvSUwyMHZNR3QwTlRFU0FtVnVLQUFQAQ

Example — Technology news (US):

https://news.google.com/rss/topics/CAAqJggKIiBDQkFTRWdvSUwyMHZNRGRqTVhZU0FtVnVHZ0pWVXlnQVAB?hl=en-US&gl=US&ceid=US:en

Note: Topic IDs are base64-encoded protocol buffer strings. They can differ by language/region. The IDs above are for en-US. To find topic IDs for other locales, inspect the RSS link on the Google News website for that locale.


3. Keyword / Search Feeds

Returns articles matching a search query.

URL pattern:

https://news.google.com/rss/search?q={query}&hl={hl}&gl={gl}&ceid={gl}:{lang}

Query modifiers:

ModifierDescriptionExample
+ or spaceAND (default)q=artificial+intelligence
OROR operatorq=Tesla+OR+SpaceX
-Exclude termq=Apple+-fruit
"..."Exact phrase (URL-encode the quotes)q=%22climate+change%22
when:7dTime filter — last N days/hoursq=Bitcoin+when:7d
when:1hTime filter — last 1 hourq=breaking+news+when:1h
after:YYYY-MM-DDArticles after a dateq=Olympics+after:2024-07-01
before:YYYY-MM-DDArticles before a dateq=Olympics+before:2024-08-15
site:Restrict to a domainq=AI+site:reuters.com

Example — search for "artificial intelligence" in the last 7 days:

https://news.google.com/rss/search?q=artificial+intelligence+when:7d&hl=en-US&gl=US&ceid=US:en

RSS Response Format

All feeds return RSS 2.0 XML. Here is the general structure:

<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:media="http://search.yahoo.com/mrss/" version="2.0">
  <channel>
    <generator>NFE/5.0</generator>
    <title>Top stories - Google News</title>
    <link>https://news.google.com/?hl=en-US&amp;gl=US&amp;ceid=US:en</link>
    <language>en-US</language>
    <webMaster>news-webmaster@google.com</webMaster>
    <copyright>...</copyright>
    <lastBuildDate>Wed, 18 Feb 2026 20:50:00 GMT</lastBuildDate>
    <item>
      <title>Article headline - Publisher Name</title>
      <link>https://news.google.com/rss/articles/...</link>
      <guid isPermaLink="true">https://news.google.com/rss/articles/...</guid>
      <pubDate>Wed, 18 Feb 2026 19:05:07 GMT</pubDate>
      <description>
        <!-- HTML ordered list of related articles -->
        <ol>
          <li><a href="...">Article Title</a>&nbsp;&nbsp;<font color="#6f6f6f">Publisher</font></li>
          ...
        </ol>
      </description>
      <source url="https://publisher-domain.com">Publisher Name</source>
    </item>
    <!-- more <item> elements -->
  </channel>
</rss>

Key Fields per <item>

FieldDescription
<title>Headline text followed by - Publisher Name
<link>Google News redirect URL. Visiting it in a browser redirects to the actual article.
<guid>Unique identifier (same as <link>)
<pubDate>Publication date in RFC 2822 format
<description>HTML snippet containing an ordered list (<ol>) of related/clustered articles with links and publisher names
<source url="...">Publisher name and homepage URL

Common Patterns

Fetch Top Headlines (curl + grep)

curl -s "https://news.google.com/rss?hl=en-US&gl=US&ceid=US:en" \
  | grep -oP '<title>\K[^<]+'

Fetch Top Headlines (Python)

import feedparser

feed = feedparser.parse(
    "https://news.google.com/rss?hl=en-US&gl=US&ceid=US:en"
)

for entry in feed.entries:
    print(f"{entry.published} — {entry.title}")
    print(f"  Link: {entry.link}")
    print()

Fetch Topic Feed (curl + xmllint)

TOPIC="CAAqJggKIiBDQkFTRWdvSUwyMHZNRGRqTVhZU0FtVnVHZ0pWVXlnQVAB"
curl -s "https://news.google.com/rss/topics/${TOPIC}?hl=en-US&gl=US&ceid=US:en" \
  | xmllint --xpath '//item/title/text()' -

Search for Articles (Python)

import feedparser
import urllib.parse

query = urllib.parse.quote("artificial intelligence when:7d")
url = f"https://news.google.com/rss/search?q={query}&hl=en-US&gl=US&ceid=US:en"

feed = feedparser.parse(url)
for entry in feed.entries[:10]:
    print(f"• {entry.title}")

Fetch News for a Specific Location (Node.js)

const https = require("https");
const { parseStringPromise } = require("xml2js");

const url =
  "https://news.google.com/rss?hl=en-GB&gl=GB&ceid=GB:en";

https.get(url, (res) => {
  let data = "";
  res.on("data", (chunk) => (data += chunk));
  res.on("end", async () => {
    const result = await parseStringPromise(data);
    const items = result.rss.channel[0].item || [];
    items.slice(0, 10).forEach((item) => {
      console.log(item.title[0]);
    });
  });
});

Extract Related Articles from Description (Python)

import feedparser
from html.parser import HTMLParser

class RelatedParser(HTMLParser):
    def __init__(self):
        super().__init__()
        self.articles = []
        self._in_a = False
        self._href = ""
        self._text = ""

    def handle_starttag(self, tag, attrs):
        if tag == "a":
            self._in_a = True
            self._href = dict(attrs).get("href", "")
            self._text = ""

    def handle_endtag(self, tag):
        if tag == "a" and self._in_a:
            self.articles.append({"title": self._text, "link": self._href})
            self._in_a = False

    def handle_data(self, data):
        if self._in_a:
            self._text += data

feed = feedparser.parse(
    "https://news.google.com/rss?hl=en-US&gl=US&ceid=US:en"
)

for entry in feed.entries[:3]:
    print(f"\n=== {entry.title} ===")
    parser = RelatedParser()
    parser.feed(entry.description)
    for art in parser.articles:
        print(f"  • {art['title']}")
        print(f"    {art['link']}")

Build a Multi-Region News Aggregator (Python)

import feedparser

REGIONS = {
    "US":  "hl=en-US&gl=US&ceid=US:en",
    "UK":  "hl=en-GB&gl=GB&ceid=GB:en",
    "DE":  "hl=de&gl=DE&ceid=DE:de",
    "JP":  "hl=ja&gl=JP&ceid=JP:ja",
    "BR":  "hl=pt-BR&gl=BR&ceid=BR:pt-419",
}

for region, params in REGIONS.items():
    feed = feedparser.parse(f"https://news.google.com/rss?{params}")
    print(f"\n--- {region} Top 3 ---")
    for entry in feed.entries[:3]:
        print(f"  • {entry.title}")

Monitor a Topic with Polling (bash)

#!/usr/bin/env bash
FEED="https://news.google.com/rss/search?q=breaking+news+when:1h&hl=en-US&gl=US&ceid=US:en"
SEEN_FILE="/tmp/gnews_seen.txt"
touch "$SEEN_FILE"

while true; do
  curl -s "$FEED" | grep -oP '<guid[^>]*>\K[^<]+' | while read -r guid; do
    if ! grep -qF "$guid" "$SEEN_FILE"; then
      echo "$guid" >> "$SEEN_FILE"
      TITLE=$(curl -s "$FEED" | grep -oP "<item>.*?<guid[^>]*>${guid}.*?</item>" \
        | grep -oP '<title>\K[^<]+' | head -1)
      echo "[NEW] $TITLE"
    fi
  done
  sleep 120
done

Resolving Google News Redirect URLs

Article links in the RSS feed point to https://news.google.com/rss/articles/... which redirect (HTTP 302/303) to the actual publisher URL. To resolve the final URL:

curl

curl -Ls -o /dev/null -w '%{url_effective}' \
  "https://news.google.com/rss/articles/CBMiWkFV..."

Python

import requests

response = requests.head(
    "https://news.google.com/rss/articles/CBMiWkFV...",
    allow_redirects=True,
    timeout=10,
)
print(response.url)  # final publisher URL

Rate Limits

Google does not publish official rate limits for the RSS feeds. Based on community observations:

GuidelineRecommendation
Polling interval≥ 60 seconds between requests for the same feed
Concurrent requestsKeep below ~10 concurrent connections
Burst behaviorRapid bursts may trigger HTTP 429 or CAPTCHA challenges
User-AgentUse a descriptive User-Agent; empty or bot-like strings may be blocked

If you receive an HTTP 429 response, back off exponentially (e.g., 1 min → 2 min → 4 min).


Error Handling

HTTP StatusMeaningAction
200SuccessParse the RSS XML
301/302RedirectFollow the redirect (most HTTP clients do this automatically)
404Feed not foundCheck the URL, topic ID, or locale parameters
429Rate limitedBack off and retry after a delay
5xxServer errorRetry with exponential backoff

Tips

  • No auth needed — all feeds are fully public. Start fetching immediately.
  • Use feedparser in Python — it handles RSS parsing, date normalization, and encoding edge cases.
  • Combine search modifiersq=Tesla+site:reuters.com+when:30d for precise results.
  • Topic IDs are locale-specific — an English topic ID may not work with hl=de. Inspect the Google News page in that locale to find the correct ID.
  • The <description> field is HTML — it contains clustered/related articles as an <ol> list. Parse the HTML to extract multiple sources per story.
  • The <title> includes the publisher — the format is Headline text - Publisher Name. Split on - (space-dash-space) from the right to separate them.
  • Feed results are limited — Google typically returns ~100 items per feed. Use search with date filters to paginate through older results.
  • Respect the copyright notice — Google's RSS feeds are intended for personal, non-commercial use in feed readers. Review Google's terms for other uses.
  • Resolve redirects lazily — only resolve the Google redirect URL to the publisher URL when you actually need the final link. This saves requests.
  • Set a proper User-Agent — e.g., User-Agent: MyNewsBot/1.0 (contact@example.com). Some environments may get blocked without one.

Changelog

  • 0.1.0 — Initial release with top stories, topic feeds, search feeds, multi-region support, and common usage patterns.

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

General

openfootball

No summary provided by upstream source.

Repository SourceNeeds Review
General

polymarket

No summary provided by upstream source.

Repository SourceNeeds Review
General

kalshi

No summary provided by upstream source.

Repository SourceNeeds Review
General

manifold

No summary provided by upstream source.

Repository SourceNeeds Review
google-news | V50.AI