Google Finance — Data via API Interna sin Auth
Skill para extraer datos de
Google Finance
via su
endpoint RPC interno descubierto por reverse
engineering —
sin API key, sin autenticacion.
Cubre quote, OHLC historico (intraday 1-min / 5-min / daily / 6-meses),
financials masivos, earnings, analyst recommendations con opinions
individuales (Goldman, etc), descripcion empresa con address+employees,
peers, news (con thumbnails), indices globales (Dow/S&P/NASDAQ/VIX/DAX/FTSE/Nikkei)
y sectors heatmap.
⚠️ WARNINGS CRITICOS — LEER PRIMERO
Antes de usar este skill en cualquier escenario productivo, leer
obligatoriamente
references/LIMITATIONS_TROUBLESHOOTING.md
.
TL;DR de los 4 warnings principales
- 🚨 API NO oficial — Google puede renombrar RPCs, cambiar layouts,
agregar auth o cerrar el endpoint sin aviso.
- 🚨 Layouts SIN keys — Los responses son arrays posicionales. Si
Google reordena campos, vas a leer mal sin error visible.
- 🚨 Rate limiting muy agresivo — > 5 req/s puede bloquear tu IP por
horas. Recomendado: sleep ≥ 0.5s entre requests.
- 🚨 Sin warranty de continuidad — Si construis algo importante,
tener fallback con otro provider (Yahoo Finance, TradingView, Finnhub).
Cuando NO usar este skill
- Trading en produccion con decisiones criticas (usar feeds oficiales).
- Aplicaciones publicas que sirvan los datos a usuarios.
- Volumen > 10k requests/dia (riesgo de bloqueo permanente de IP).
- Redistribuir los datos como propios (terminos de uso de Google).
Cuando SI usar este skill
- Investigacion personal y prototipos.
- Backtest con cache local.
- Analisis comparativo cruzado con otros providers.
- Casos donde los datos UNICOS de Google son criticos (intraday 1-min
gratis, detalle individual de analyst opinions).
🚀 Quick start
bash
# Quote basico
py scripts/fetch_gfinance.py quote GGAL:NASDAQ
py scripts/fetch_gfinance.py quote AAPL:NASDAQ
py scripts/fetch_gfinance.py quote GGAL:BCBA # mercado argentino
# Intraday del dia actual
py scripts/fetch_gfinance.py intraday-5min AAPL:NASDAQ
py scripts/fetch_gfinance.py intraday-1min GGAL:NASDAQ
# Daily historico
py scripts/fetch_gfinance.py daily-6m AAPL:NASDAQ
# Indices globales (Dow, S&P, NASDAQ, VIX, DAX, FTSE, Nikkei...)
py scripts/fetch_gfinance.py indices
# Analyst recommendations + opinions individuales
py scripts/fetch_gfinance.py analysts NVDA:NASDAQ
# Todo en uno (6 requests pipelinadas)
py scripts/fetch_gfinance.py all GGAL:NASDAQ
Estructura del skill
skills/google-finance/
├── SKILL.md # Este archivo
├── references/ # 5 documentos
│ ├── REFERENCE.md # Overview general + batchexecute
│ ├── RPC_IDS.md # Catalogo de los 14+ RPC IDs
│ ├── RESPONSE_FORMAT.md # Parser deep dive del wrb.fr protocol
│ ├── LIMITATIONS_TROUBLESHOOTING.md # ⚠️ Warnings, plan B, debugging
│ └── COOKBOOK.md # 25 recetas listas
├── assets/ # 3 archivos JSON
│ ├── rpc_ids.json # Catalogo estructurado de RPCs + args
│ ├── chunk_layouts.json # Layouts posicionales de los arrays
│ └── consent_cookies.json # Cookies de bypass del consent
└── scripts/
└── fetch_gfinance.py # Script principal — 19 modos CLI
19 modos CLI disponibles
Por simbolo
| Modo | Data | RPC ID |
|---|
| Precio + change + currency + market hours | |
| Quote + industry + market cap + volume | |
| Descripcion + address + employees + ratios + URLs | |
| Related stocks (default 4, controlable con ) | |
| Recommendations summary + opinions individuales | |
| Earnings history multi-period | |
| Ratings tecnicos (similar a TradingView Recommend.*) | |
| Income + balance + cashflow ~22 KB multi-period | |
| OHLC 1-min del dia actual (~30 KB) | |
| OHLC 5-min con OHLC completo (~5 KB) | |
| OHLC diario ultimo mes (~22 dias) | |
| OHLC diario ultimos ~6 meses | |
| News especificas del simbolo | |
| News globales (con related symbols del query) | |
Globales (sin simbolo)
| Modo | Data | RPC ID |
|---|
| Indices globales: Dow, S&P, NASDAQ, VIX, DAX, FTSE, Nikkei, etc | |
| Sectors equity heatmap (Health Care, Tech, etc) | |
Catalogos locales (sin HTTP)
| Modo | Data |
|---|
| Catalogo de RPC IDs con args templates y descripciones |
| Layouts posicionales de los arrays anidados |
| Cookies de bypass del consent screen |
Combinado
| Modo | Data |
|---|
| quote + description + analysts + financials + daily + news (6 requests) |
Formato de simbolos
| Donde | Formato | Ejemplos |
|---|
| Tickers US | o | , |
| ADRs argentinas | o | , |
| Tickers BCBA (locales argentinas) | | , |
| Brazil B3 | | |
| Spain BME | | |
| Germany Xetra | | |
| Indices | IDX:INDEXSP/DJX/NASDAQ/CBOE
| , |
El script tambien acepta el orden invertido (
) — auto-detecta
cual es el exchange. Pero el formato canonical de Google es
.
Diferenciales unicos vs otros skills del repo
| Feature | Google Finance | TradingView | Yahoo | Finnhub |
|---|
| Sin auth | ✅ | ✅ | ✅ | Freemium |
| OHLC intraday 1-min publico gratis | ✅ UNICO | ❌ (paid) | ⚠️ limited | ⚠️ paid |
| OHLC 5-min completo | ✅ | ❌ | ⚠️ | ⚠️ |
| Indices globales en 1 call (Dow+S&P+NASDAQ+VIX+DAX+FTSE+Nikkei...) | ✅ UNICO | ⚠️ uno por uno | ⚠️ | ⚠️ |
| Detalle individual de analyst opinions (nombre, firm, target, fecha) | ✅ UNICO | ⚠️ solo agregado | ⚠️ | ✅ |
| Sectors heatmap | ✅ | ⚠️ | ❌ | ❌ |
| Descripcion empresa con address fisico + employees | ✅ UNICO | ⚠️ | ⚠️ | ✅ |
| Quote delayed | ✅ | ✅ | ✅ | ✅ |
| Financials | ✅ (~22 KB) | ✅ | ✅ | ✅ |
| News con thumbnails | ✅ | ✅ | ✅ | ✅ |
Cuando usar Google Finance > TradingView
- Necesitas OHLC intraday 1-min sin pagar.
- Necesitas detalle individual de opinions por analista con firma/target/fecha.
- Necesitas el address fisico de una empresa argentina.
- Necesitas indices globales (Dow+S&P+NASDAQ+VIX+DAX+FTSE+Nikkei) en una sola call.
Cuando usar TradingView > Google Finance
- Necesitas screener masivo con filtros tipo SQL.
- Necesitas ISIN/CUSIP/CIK del simbolo (Symbol Search v3).
- Necesitas indicadores tecnicos pre-calculados (RSI/MACD/EMAs/pivots).
- Necesitas robustez — TV es mucho mas estable que Google Finance.
Consideraciones tecnicas
Endpoint
POST https://www.google.com/finance/beta/_/FinHubUi/data/batchexecute?rpcids={RPC_ID}
Headers requeridos
Ya configurados en el script:
python
HEADERS = {
"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36",
"Content-Type": "application/x-www-form-urlencoded;charset=UTF-8",
"X-Same-Domain": "1", # CRITICO
"Origin": "https://www.google.com",
"Referer": "https://www.google.com/finance/...",
}
Cookies de bypass
El script las pasa automaticamente:
python
COOKIES = {
"CONSENT": "PENDING+999",
"SOCS": "CAESHAgBEhJnd3NfMjAyNTAxMjMtMF9SQzMaAmVuIAEaBgiAvLW8Bg",
}
Si dejan de funcionar, ver LIMITATIONS_TROUBLESHOOTING.md seccion 6
para capturar cookies frescas.
Response format (wrb.fr)
Los responses usan el protocolo
wrb.fr de Google (XSSI prefix + JSON
serializado doble). El script tiene un
que lo maneja.
Detalles en
RESPONSE_FORMAT.md.
Rate limiting
⚠️ Aggressive. Recomendado:
- Sleep ≥ 0.5s entre requests.
- < 1k requests/dia para no triggear bloqueo IP.
- NO usar desde CI sin precauciones (cloud IPs en blacklist).
Output
- Por defecto: JSON al stdout.
- : guarda a archivo (UTF-8, ).
- : modo silencioso (sin logs INFO).
- : retorna response raw sin extraer del array wrb.fr.
Manejo de errores
El script captura
y muestra el body para debugging.
Si el endpoint deja de funcionar, te apunta a
LIMITATIONS_TROUBLESHOOTING.md
.
Casos comunes — recetas rapidas
25 recetas completas en COOKBOOK.md.
bash
# Quote rapido
py scripts/fetch_gfinance.py quote GGAL:NASDAQ -q
# Stock argentino BCBA
py scripts/fetch_gfinance.py quote GGAL:BCBA -q
# Indices globales del dia
py scripts/fetch_gfinance.py indices -q
# Intraday 5-min con OHLC completo
py scripts/fetch_gfinance.py intraday-5min AAPL:NASDAQ -o aapl_5min.json
# Daily ultimos 6 meses
py scripts/fetch_gfinance.py daily-6m AAPL:NASDAQ -o aapl_6m.json
# Analyst recommendations + opinions individuales
py scripts/fetch_gfinance.py analysts NVDA:NASDAQ -q
# Comparar empresa con peers
py scripts/fetch_gfinance.py peers GGAL:NASDAQ --peers-count 5 -q
# Todo-en-uno (snapshot completo)
py scripts/fetch_gfinance.py all GGAL:NASDAQ -o ggal_complete.json
Documentacion completa
| Documento | Contenido |
|---|
| Overview general + batchexecute deep dive |
| Catalogo detallado de los 14+ RPC IDs con args + outputs |
references/RESPONSE_FORMAT.md
| Parser deep dive del wrb.fr (XSSI, doble JSON, edge cases) |
references/LIMITATIONS_TROUBLESHOOTING.md
| ⚠️ Warnings, debugging, plan B con providers alternativos |
| 25 recetas listas para copy-paste |
| Catalogo de RPCs con args templates y descripciones |
assets/chunk_layouts.json
| Layouts posicionales de cada array (que indice = que campo) |
assets/consent_cookies.json
| Cookies de bypass del consent screen |
Inspiracion y atribuciones
Este skill fue construido a partir de research del HTML de
google.com/finance/beta/quote/GGAL:NASDAQ
, identificando los chunks
con su sistema "Wiz" (mismo que usa Search, Maps,
Translate). El protocolo wrb.fr es publico y bien documentado por la
comunidad (no por Google).
Implementaciones similares en otros lenguajes:
- (Node.js) — usa el mismo endpoint
- (Python, distinto enfoque)
- Multiples proyectos OSS de scraping de finance.google.com
Este skill se distingue por:
- 24 modos CLI sobre 14+ RPC IDs distintos.
- Documentacion exhaustiva de los warnings y plan B.
- Catalogo estructurado de RPCs + layouts posicionales en assets.
- Parser robusto del wrb.fr con manejo de todos los edge cases.