美股 (US) 与 墨西哥 (Mexico) 股票数据接口集成指南

1. 接入概述 (General)

本接口用于获取美国(NYSE, NASDAQ, AMEX)及墨西哥(BMV, BIVA)证券市场的实时行情、历史 K 线及指数数据。

  • API Base URL : https://api.stocktv.top
  • WebSocket URL : wss://ws-api.stocktv.top/connect
  • 鉴权方式 : 所有请求均需携带 URL 参数 key=您的API密钥

1.1 关键市场 ID (Country ID)

在调用相关接口时,请务必区分以下 countryId

市场名称 Country ID 交易所示例
美国 (USA) 5 NYSE (1), NASDAQ (2), AMEX
墨西哥 (Mexico) 7 Mexico (53), BIVA (144)

2. 核心数据接口

2.1 获取股票列表 (Stock List)

用于查询指定市场的股票清单,获取股票的名称、代码 (Symbol) 和 系统 ID (PID)

注意id (PID) 是后续查询 K 线和订阅 WebSocket 的唯一标识符。

  • 接口地址 : /stock/stocks
  • 请求方式 : GET
  • 请求参数:
参数名 类型 必填 说明
key String 您的 API Key
countryId Int 5 (美股) 或 7 (墨西哥)
pageSize Int 每页数量 (默认 10)
page Int 页码 (默认 1)
  • 请求示例 (获取美股列表):

    http 复制代码
    GET https://api.stocktv.top/stock/stocks?countryId=5&pageSize=20&page=1&key=YOUR_KEY
  • 响应示例:

    json 复制代码
    {
      "code": 200,
      "data": {
        "records": [
          {
            "id": 8888,          // [关键] PID,用于K线接口
            "name": "Apple Inc", // 股票名称
            "symbol": "AAPL",    // 股票代码
            "exchangeId": 2,     // 交易所ID (2=NASDAQ)
            "last": 180.5,       // 最新价
            "chgPct": 1.25,      // 涨跌幅%
            "countryNameTranslated": "United States"
          }
        ]
      }
    }

2.2 获取 K 线数据 (Candlestick Data)

获取指定股票的历史行情数据,支持多种时间周期。

  • 接口地址 : /stock/kline
  • 请求方式 : GET
  • 请求参数:
参数名 类型 必填 说明
key String 您的 API Key
pid Int 股票系统 ID (通过 2.1 接口获取)
interval String K线周期 (ISO 8601格式)
  • 周期 (Interval) 说明:

    • PT1M (1分钟), PT5M (5分钟), PT15M (15分钟), PT30M (30分钟), PT1H (1小时)
    • P1D (日线), P1W (周线), P1M (月线)
  • 请求示例 (获取墨西哥某股票日线):

    http 复制代码
    GET https://api.stocktv.top/stock/kline?pid=12345&interval=P1D&key=YOUR_KEY
  • 响应示例:

    json 复制代码
    {
      "code": 200,
      "data": [
        {
          "time": 1719818400000, // 时间戳 (毫秒)
          "open": 150.0,
          "high": 155.0,
          "low": 149.0,
          "close": 153.0,
          "volume": 200000
        }
      ]
    }

2.3 获取大盘指数 (Indices)

获取美股(如纳斯达克、标普500)或墨西哥(如 S&P/BMV IPC)的指数行情。

  • 接口地址 : /stock/indices

  • 请求方式 : GET

  • 请求参数 : countryId (5=美国, 7=墨西哥)

  • 请求示例:

    http 复制代码
    GET https://api.stocktv.top/stock/indices?countryId=7&key=YOUR_KEY

3. WebSocket 实时推送

通过 WebSocket 长连接接收实时报价更新。

  • 连接地址 : wss://ws-api.stocktv.top/connect?key=YOUR_KEY

  • 心跳机制: 连接建立后,建议定期发送心跳包以保持连接。

  • 推送数据结构 :

    json 复制代码
    {
        "pid": "8888",         // 对应 Rest API 中的 id
        "last_numeric": 181.2, // 最新价
        "pcp": "0.39",         // 涨跌幅%
        "timestamp": "1717728251",
        "bid": "181.1",        // 买价
        "ask": "181.3",        // 卖价
        "type": 1              // 1=股票, 2=指数
    }

4. 接入代码示例 (JavaScript)

以下代码展示了如何根据 countryId 封装获取美股和墨西哥股票的逻辑。

javascript 复制代码
const API_KEY = 'YOUR_API_KEY';
const BASE_URL = 'https://api.stocktv.top';

// 配置 ID
const MARKETS = {
    USA: 5,
    MEXICO: 7
};

/**
 * 获取指定市场的股票列表
 * @param {number} countryId - 5 for USA, 7 for Mexico
 */
async function getMarketStocks(countryId) {
    const url = `${BASE_URL}/stock/stocks?countryId=${countryId}&pageSize=10&page=1&key=${API_KEY}`;
    try {
        const response = await fetch(url);
        const result = await response.json();
        
        if (result.code === 200) {
            console.log(`市场 (ID:${countryId}) 股票列表:`, result.data.records);
            // 示例:获取第一个股票的 PID 用于查 K 线
            if(result.data.records.length > 0) {
                const firstStock = result.data.records[0];
                console.log(`示例股票: ${firstStock.name}, PID: ${firstStock.id}`);
            }
        }
    } catch (error) {
        console.error('API 请求失败:', error);
    }
}

// 1. 获取美股数据
getMarketStocks(MARKETS.USA);

// 2. 获取墨西哥股票数据
getMarketStocks(MARKETS.MEXICO);
相关推荐
风象南11 分钟前
普通人用AI加持赚到的第一个100块
人工智能·后端
冰_河2 小时前
QPS从300到3100:我靠一行代码让接口性能暴涨10倍,系统性能原地起飞!!
java·后端·性能优化
JavaGuide5 小时前
7 道 RAG 基础概念知识点/面试题总结
前端·后端
桦说编程5 小时前
从 ForkJoinPool 的 Compensate 看并发框架的线程补偿思想
java·后端·源码阅读
格砸6 小时前
从入门到辞职|从ChatGPT到OpenClaw,跟上智能时代的进化
前端·人工智能·后端
蝎子莱莱爱打怪6 小时前
GitLab CI/CD + Docker Registry + K8s 部署完整实战指南
后端·docker·kubernetes
哈密瓜的眉毛美6 小时前
零基础学Java|第三篇:DOS 命令、转义字符、注释与代码规范
后端
用户60572374873087 小时前
AI 编码助手的规范驱动开发 - OpenSpec 初探
前端·后端·程序员
哈密瓜的眉毛美7 小时前
零基础学Java|第二篇:Java 核心机制与第一个程序:从 JVM 到 Hello World
后端