当前位置: 首页 > news >正文

使用WebSocket实时获取印度股票数据源(无调用次数限制)实战


使用WebSocket实时获取印度股票数据源(无调用次数限制)实战


一、前置准备

1. 获取API密钥

登录 StockTV开发者平台 → 联系客服获取测试Key(格式MY4b781f618e3f43c4b055f25fa61941ad),该密钥无调用次数限制且支持实时数据持续订阅。

2. 安装Python依赖

pip install websocket-client json pandas

二、核心代码实现

1. 建立WebSocket连接

import websocket
import json
import timeAPI_KEY = "YOUR_API_KEY"
WS_URL = f"wss://ws-api.stocktv.top/connect?key={API_KEY}"def on_message(ws, message):"""处理实时行情推送"""data = json.loads(message)if data.get('type') == 'stock':print(f"[{data['symbol']}] 价格: {data['last']} 涨跌幅: {data['pcp']}%")def on_error(ws, error):print(f"连接异常: {error}")def on_close(ws, close_status_code, close_msg):print(f"连接关闭: {close_msg}")def on_open(ws):"""连接成功后订阅股票"""subscribe_msg = json.dumps({"action": "subscribe","symbols": ["RELIANCE", "NSEI"]  # 印度信实工业/Nifty50指数})ws.send(subscribe_msg)print("订阅成功,开始接收实时数据...")

2. 启动实时监听(含自动重连)

def start_websocket():while True:try:ws = websocket.WebSocketApp(WS_URL,on_message=on_message,on_error=on_error,on_close=on_close)ws.on_open = on_openws.run_forever()except Exception as e:print(f"连接异常,5秒后重连: {str(e)}")time.sleep(5)# 启动线程持续运行
import threading
threading.Thread(target=start_websocket, daemon=True).start()

3. 添加心跳机制(保持长连接)

def send_heartbeat(ws):"""每30秒发送心跳包"""while True:try:ws.send(json.dumps({"action": "ping"}))time.sleep(30)except Exception as e:break# 在on_open函数中启动心跳线程
def on_open(ws):# ...原有订阅代码...threading.Thread(target=send_heartbeat, args=(ws,), daemon=True).start()

三、实时数据示例输出

订阅成功,开始接收实时数据...
[RELIANCE] 价格: 2856.15 涨跌幅: +1.23%
[NSEI] 价格: 22985.40 涨跌幅: +0.75%
[RELIANCE] 价格: 2857.80 涨跌幅: +1.35% 

四、关键参数说明

字段说明示例值
symbol股票/指数代码RELIANCE, NSEI
last最新成交价2856.15
pcp涨跌幅百分比(自动带±号)+1.23%
volume成交量(股)1254875
timestamp数据时间戳(Unix毫秒级)1725002394123

五、注意事项

  1. 连接稳定性
    通过自动重连机制+心跳包保障7×24小时持续运行

  2. 数据时效性
    印度市场交易时段为IST 9:15-15:30(北京时间11:45-18:00),非交易时段无实时数据推送

  3. 性能优化
    建议使用异步处理框架(如asyncio)避免数据堆积,实测单连接可承载100+标的实时推送


相关文章:

  • MyBatis————入门
  • onSaveInstanceState() 和 ViewModel 在数据保存能力差异
  • 电动螺丝刀-多实体拆图建模案例
  • 练习:对象数组 4
  • 中医的十问歌和脉象分类
  • D1675/HBT191单通道高清视频放大电路解析
  • day45python打卡
  • DAY45 可视化
  • 现代Web安全实践:基于Token与Refresh Token的单点登录(SSO)实现
  • Dify工具插件开发和智能体开发全流程
  • ​​TPS3808​​低静态电流、可编程延迟电压监控电路,应用笔记
  • 深入理解数字音频:采样率、位深与量化
  • CSDN文章下载到本地的完整指南
  • [c#]判定当前软件是否用管理员权限打开
  • 数论——同余问题全家桶3 __int128和同余方程组
  • AI智能编码工具:阿里通义灵码使用个人版
  • 33 C 语言字符串转数值函数详解:atoi、atol、atoll、atof
  • 如何选择正确的团队交互模式:协作、服务还是促进?
  • 现实生活例子[特殊字符] 通俗易懂的解释[特殊字符] JS中的原型和原型链[特殊字符]
  • 2018~2025:英伟达在具身智能机器人领域的关键布局详解
  • 平乡县网站建设平台/淘宝seo具体优化方法
  • 苏州建设局网站实名制/有网站模板怎么建站
  • 简约式网站模板/排名seo怎么样
  • 合肥专业做公司网站/做一个企业网站大概需要多少钱
  • 刷单做任务的网站/新出的app推广在哪找
  • 桂林网站建设官网/广告免费推广网