BYMA — Bolsas y Mercados Argentinos
Skill para extraer datos de mercado de
BYMA
via su
API publica de market data (
) — sin API
key, sin autenticacion.
BYMA es la bolsa principal de Argentina (sucesora del Merval) donde se
negocian:
- Acciones lideres (panel de 20 simbolos del MERVAL).
- CEDEARs (~1143 unicos x 2 settlements).
- Bonos publicos soberanos + LECAPs + BONCAPs (~104 unicos x 6 variantes).
- Obligaciones Negociables (ON) corporativas (~2117 items).
- SENEBI ON (segmento bilateral, ~3160 items).
- Cauciones (133 items, formato ).
- Opciones (~429 items con strike, OI, vencimiento).
- Indices: S&P MERVAL (), BURCAP ().
- Historicos OHLCV diarios/semanales/mensuales para todos los instrumentos.
- Ficha tecnica de bonos (forma de amortizacion, intereses step-up, ISIN, ley aplicable, emisor).
⚠️ Aviso Legal
- API publica de BYMA, sin documentacion oficial. Los endpoints pueden cambiar sin aviso.
- Respetar terminos de uso de BYMA. No hacer mas de 1 req/segundo.
- Los datos son delayed (~15 min tipico de mercado argentino).
- Para uso comercial intensivo, contactar BYMA para licencias oficiales.
🔒 Nota sobre certificado SSL
BYMA presenta un certificado SSL cuya CA intermedia no esta incluida en
el bundle
estandar de Python. Esto causa:
SSLError: CERTIFICATE_VERIFY_FAILED
El script usa — la conexion sigue siendo TLS-encriptada
pero se omite la validacion de cadena. Es el patron estandar de las
librerias publicas de BYMA (
,
, etc.).
Si preferis no usar
, podes instalar el cert intermedio de
BYMA en tu trust store del sistema.
Scripts
| Script | Descripcion |
|---|
| fetch_byma.py | Script principal: todos los endpoints disponibles |
Uso rapido
bash
# ── PANELES (POST) ────────────────────────────────────────────────────
# Panel lideres: 20 acciones MERVAL x 2 settlements (40 items)
py scripts/fetch_byma.py panel leading-equity
py scripts/fetch_byma.py panel leading-equity --t0 # solo CI (T+0)
py scripts/fetch_byma.py panel leading-equity --t1 # solo 24hs (T+1)
# Panel CEDEARs (~2000 items, lista directa)
py scripts/fetch_byma.py panel cedears
# Panel bonos publicos (1018 items, paginado a 189 por defecto)
py scripts/fetch_byma.py panel public-bonds
py scripts/fetch_byma.py panel public-bonds --all # trae los 1018 en una llamada
# Panel ON corporativas (~2117 items, lista directa)
py scripts/fetch_byma.py panel on
# Panel cauciones (~133 items)
py scripts/fetch_byma.py panel cauciones
# Panel SENEBI ON (3160 items, paginado)
py scripts/fetch_byma.py panel senebi-on
py scripts/fetch_byma.py panel senebi-on --all # trae los 3160 en una llamada
# Panel opciones (~429 items, con strike, OI, vencimiento)
py scripts/fetch_byma.py panel options
# ── HISTORICOS OHLCV (GET) ────────────────────────────────────────────
# Historico de un instrumento — formato simbolo: "TICKER 24HS"
py scripts/fetch_byma.py historico "GGAL 24HS"
py scripts/fetch_byma.py historico "ALUA 24HS"
py scripts/fetch_byma.py historico "AAPL 24HS" # CEDEAR ARS
py scripts/fetch_byma.py historico "AAPLD 24HS" # CEDEAR USD
py scripts/fetch_byma.py historico "AL30 24HS" # Bono ARS
py scripts/fetch_byma.py historico "AL30D 24HS" # Bono USD
py scripts/fetch_byma.py historico "AL30C 24HS" # Bono CCL
py scripts/fetch_byma.py historico "GD30 24HS"
py scripts/fetch_byma.py historico "TZX26 24HS" # BONCAP
py scripts/fetch_byma.py historico "TY30P 24HS" # BONCAP
# Con rango de fechas (default: ultimos 30 dias)
py scripts/fetch_byma.py historico "GGAL 24HS" --desde 2024-05-15 --hasta 2026-06-05
# Resolutions: D (diario), W (semanal), M (mensual)
py scripts/fetch_byma.py historico "GGAL 24HS" --resolution W
py scripts/fetch_byma.py historico "GGAL 24HS" --resolution M
# ── INDICES ────────────────────────────────────────────────────────────
# Historico del S&P MERVAL
py scripts/fetch_byma.py indice M
py scripts/fetch_byma.py indice M --desde 2025-01-01 --hasta 2026-06-05
# Historico del BURCAP
py scripts/fetch_byma.py indice G
# ── FICHA TECNICA DE BONOS ─────────────────────────────────────────────
# Ficha tecnica completa: forma de amortizacion, intereses, ISIN, ley, emisor
py scripts/fetch_byma.py bond-info AE38 # Bono soberano USD 2038 step-up
py scripts/fetch_byma.py bond-info AL30 # Bono soberano USD 2030 ley local
py scripts/fetch_byma.py bond-info GD30 # Bono soberano USD 2030 ley NY
py scripts/fetch_byma.py bond-info AE38C # Variante CCL (misma ficha)
py scripts/fetch_byma.py bond-info AE38D # Variante USD MEP (misma ficha)
py scripts/fetch_byma.py bond-info BPOA7 # BOPREAL Serie 1 A
py scripts/fetch_byma.py bond-info TY30P # BONCAP
py scripts/fetch_byma.py bond-info TZX26 # BONCAP CER
py scripts/fetch_byma.py bond-info S237Q # LECAP
py scripts/fetch_byma.py bond-info SBC1C # ON corporativa
# ── COMBINADO ──────────────────────────────────────────────────────────
# Snapshot de todos los paneles + MERVAL + BURCAP
py scripts/fetch_byma.py all
# ── OUTPUT ─────────────────────────────────────────────────────────────
# Guardar a archivo JSON
py scripts/fetch_byma.py panel leading-equity -o leading.json
py scripts/fetch_byma.py all -o snapshot_byma.json
# Modo silencioso (solo JSON, sin logs)
py scripts/fetch_byma.py panel cauciones -q
Endpoints disponibles
| Modo | Data | Endpoint |
|---|
| Top 20 acciones MERVAL x 2 settlements (40 items) | |
| CEDEARs (~2000 items) | |
| Bonos soberanos + LECAPs/BONCAPs (~1018 items) | |
| ONs corporativas (~2117 items) | POST /negociable-obligations
|
| Cauciones (~133 items) | |
| SENEBI ONs (~3160 items, paginado) | POST /senebi-obligaciones-negociables
|
| Opciones (~429 items) | |
| OHLCV diario/semanal/mensual de un instrumento | GET /chart/historical-series/history?symbol={...}
|
| OHLCV de un indice (M=MERVAL, G=BURCAP) | GET /chart/index-historical-series/history?symbol={...}
|
| Ficha tecnica de bono/LECAP/BONCAP/ON (amortizacion, intereses, ISIN, emisor) | POST /bnown/fichatecnica/especies/general
|
| Snapshot de todos los paneles + indices | (combinado) |
Total: 10 endpoints publicos verificados ✅ (8 POST + 2 historicos GET).
Base URL
https://open.bymadata.com.ar/vanoms-be-core/rest/api/bymadata/free
Convenciones de simbolos
Historicos: formato
⚠️
TODOS los historicos requieren el sufijo (con espacio).
Sin sufijo retorna HTTP 400. El sufijo
tambien retorna 400 (no
soportado).
retorna 200 con 0 puntos.
| Tipo | Ejemplo |
|---|
| Accion | , , |
| CEDEAR ARS | , |
| CEDEAR USD | , |
| Bono soberano ARS | , , |
| Bono soberano USD MEP | , |
| Bono soberano CCL | , |
| LECAP/BONCAP | , |
Bonos: convencion de sufijos por moneda
| Sufijo | Variante | Ejemplo |
|---|
| (sin) | ARS — paridad en pesos | |
| CCL (Contado con Liquidacion / EXT) | |
| USD MEP | |
| , , | otras variantes (intra-day, settlement alt.) | |
Indices conocidos
| Codigo | Indice |
|---|
| S&P MERVAL |
| BURCAP |
Otros codigos (A, B, V, etc.) son aceptados pero retornan series con
todos ceros — probablemente indices deprecated.
Filtros comunes en POST paneles
| Filtro | Descripcion |
|---|
| Solo (CI / Contado Inmediato) |
| Solo (24hs) |
| Solo (48hs — practicamente vacio) |
| Trae todo el dataset en una sola llamada (recomendado para y ) |
⚠️ El parametro
(numero de pagina)
es ignorado por la API —
siempre devuelve pagina 1. Workaround: usar
grande o flag
.
Consideraciones tecnicas
Datos devueltos por (todos)
Cada item incluye:
| Campo | Tipo | Descripcion |
|---|
| string | Ticker BYMA. |
| string | (CI) o (24hs). |
| string | (Common Stock), (CEDEAR), (Government Obligation), (ON), (Caucion), (Option). |
| string | , , . |
| string | o . |
| float | Ultimo precio operado. |
| float | Cierre del dia. |
| float | Precio de settlement. |
| , , | float | OHL del dia. |
| , | float | Cierre / settlement anterior. |
| float | Variacion % vs anterior (decimal: -0.0098 = -0.98%). |
| , | float | Volumen nominal. |
| float | Monto efectivo en moneda. |
| float | Volume-Weighted Average Price. |
| , | float | Mejor bid/offer (0 fuera de horario). |
| , | float | Cantidades de bid/offer. |
| int | Numero total de ordenes del dia. |
| float | Interes abierto (real en opciones/cauciones; 0 en acciones). |
| int | -1 / 0 / +1 (downtick / unchanged / uptick). |
| string | Hora del ultimo trade. |
Campos extra en bonos / ONs / cauciones / opciones
| Campo | Descripcion |
|---|
| Fecha de vencimiento (ISO ). |
| Dias hasta vencimiento. |
| Underlying (solo cauciones y opciones). |
| o (solo opciones). |
Datos devueltos por e
json
{
"s": "ok",
"t": [unix_seconds, ...],
"o": [opens, ...],
"h": [highs, ...],
"l": [lows, ...],
"c": [closes, ...],
"v": [volumes, ...]
}
| Campo | Descripcion |
|---|
| Status: , , . |
| Timestamps unix UTC SECONDS (no millis). |
| , , , | OHLC alineados por indice. |
| Volumen (suele ser 0 en indices). |
Datos devueltos por
Devuelve
{content, data, empty, upgrade}
donde
(cuando existe)
contiene la ficha tecnica del bono. Para acciones, opciones y tickers
inexistentes:
y
.
| Campo | Tipo | Descripcion |
|---|
| string | Jurisdiccion aplicable: , , , . Critico para distinguir AL30 (ley local) de GD30 (ley NY). |
| string | TEXTO PLANO con el cronograma de amortizacion (numero de cuotas, periodicidad, fechas, %). Para bullet: . |
| string | TEXTO PLANO con esquema de devengo de intereses. Para step-up describe cada tramo de tasa. Para CER describe el ajuste por inflacion. |
| int | Denominacion minima de emision. |
| string | . |
| string | . |
| string | Fecha inicio devengo (suele estar vacia). |
| string | ISIN del instrumento. |
| string | , , . |
| string | Clasificacion regulatoria: Valores Publicos Nacionales
, , . |
| string | , etc. |
| string | Estado de default (vacio si esta al dia). |
| int | Monto nominal total emitido. |
| int | Monto residual actual (post-amortizaciones). |
| string | Nombre oficial completo del bono. |
| string | . |
| string | Pais de ley aplicable. |
| string | , , , . |
| string | , Provincia de Buenos Aires
, , etc. |
Diferencia entre paneles y
| Panel | Tipo response | Estructura |
|---|
| , , | dict | {content: {page_number, page_count, page_size, total_elements_count}, data: [...], empty, upgrade}
|
| , , , | list | directo |
Flags adicionales
| Flag | Descripcion |
|---|
| Forza para traer todo en una sola llamada |
| Solo settlementType=1 (CI) |
| Solo settlementType=2 (24hs) |
| Numero de pagina (ignorado por la API — usar ) |
| Items por pagina (default: 200) |
| Fecha desde (historicos) |
| Fecha hasta (historicos) |
| , , (default: ) |
| Guardar output a archivo |
| / | Modo silencioso (solo JSON) |
Rate limiting
No hay rate limiting documentado. Recomendado:
- Minimo 0.3 segundos entre requests.
- El modo usa automaticamente.
Manejo de errores
| Status | Causas tipicas |
|---|
| 400 | Simbolo invalido (sin , ticker desconocido) |
| 401 | Endpoint inexistente (BYMA usa 401 generico, no 404) |
| 415 | Content-Type erroneo (POST debe ser ) |
| 500 | Error interno de BYMA |
Conversion de fechas
python
from datetime import datetime, timezone
# Unix seconds -> datetime
dt = datetime.fromtimestamp(ts, tz=timezone.utc)
# datetime -> Unix seconds
ts = int(datetime(2026, 6, 5, tzinfo=timezone.utc).timestamp())
Estructura del skill
skills/byma/
├── SKILL.md # Este archivo (guia rapida)
├── references/
│ └── REFERENCE.md # Documentacion completa de todos los endpoints
└── scripts/
└── fetch_byma.py # Script principal
Documentacion detallada: Consultar references/REFERENCE.md
para documentacion exhaustiva de cada endpoint, schemas JSON, codigos
de settlementType/securityType, manejo del cert SSL, paginacion y
consideraciones tecnicas.