SinaL2:新浪Level2行情数据获取工具详解
2026-02-06 04:52:58作者:秋阔奎Evelyn
SinaL2是一个专门用于获取新浪Level2市场深度数据的轻量级Python客户端。该项目从dHydra框架中抽离出来,专注于行情数据的高效获取,实现了模块化和低耦合的设计,便于开发者进行二次开发和整合。
项目特点
- 支持新浪Level2数据服务的多个版本,包括普及版和标准版
- 专注于行情数据的高效获取,代码结构清晰
- 模块化设计,便于集成到其他量化交易系统
- 提供实时行情、逐笔交易数据获取功能
- 包含命令行工具方便调试和批量数据下载
安装方法
使用pip安装:
pip install SinaL2
或者从GitCode仓库克隆:
git clone https://gitcode.com/gh_mirrors/si/SinaL2
cd SinaL2
配置说明
在使用前需要配置新浪账号信息。在项目根目录创建sina.json文件:
{
"username": "您的用户名",
"password": "您的密码"
}
注意:需要在新浪购买Level2数据权限,普及版或标准版均可使用。
核心功能
数据监听
SinaL2支持实时监听多只股票的行情数据:
from SinaL2.SinaL2 import SinaL2
import threading
import time
import SinaL2.util as util
trading_date = util.get_trading_date()
def on_recv_data(message):
print(util.ws_parse(message=message, to_dict=True, trading_date=trading_date))
def start_sina_l2():
sina_l2 = SinaL2(
symbols=["sz000001","sh600221"],
on_recv_data=on_recv_data,
query=["quotation","transaction","orders"]
)
sina_l2.start()
t = threading.Thread(target=start_sina_l2)
t.setDaemon(True)
t.start()
while True:
time.sleep(10)
数据解析
SinaL2提供了完善的数据解析功能,支持将原始数据转换为字典格式:
quotation_to_dict(): 行情数据解析transaction_to_dict(): 逐笔交易数据解析orders_to_dict(): 委托数据解析
使用注意事项
- 数据使用合规性:新浪Level2数据有使用限制,禁止恶意抓取,不保证在云服务器的可用性
- 依赖包:项目依赖pandas等包,虽然基本用不到但需要安装
- 性能建议:对于高频数据处理,建议采用dHydra框架的redis消息队列与多进程处理方案
- 开源协议:项目采用Apache开源协议
应用场景
SinaL2适用于多种量化交易场景:
- 实时监控:持续监听感兴趣的股票,及时作出交易决策
- 历史数据分析:批量下载特定股票的逐笔交易记录,为策略回测提供数据基础
- 数据清洗与存储:将获取的数据清洗后存入数据库,供后续分析使用
技术架构
项目采用模块化设计,主要包含以下核心模块:
- SinaL2.py: 主客户端类,提供数据获取和连接管理
- util.py: 工具函数,包含数据解析、日志配置等功能
- Sina.py: 新浪数据接口封装
- connection.py: 网络连接管理
最佳实践建议
- 结合异步编程模型如
gevent提高数据处理效率 - 在处理大量股票实时数据时,合理配置线程和进程数量
- 定期检查数据质量,确保数据准确性
- 遵守新浪的数据使用政策,合法合规使用数据资源
SinaL2作为一个专注于Level2数据获取的工具,为量化交易开发者提供了便捷的数据接入方案,是构建个性化投资分析工具的重要基础组件。
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0186
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0111
Step-3.7-FlashStep-3.7-Flash是一个拥有 1980 亿参数的稀疏混合专家(MoE)视觉语言模型,由 1960 亿参数的语言主干网络和 18 亿参数的视觉编码器组合而成,具备原生图像理解能力。Python00
JoyAI-EchoJoyAI-Echo,这是一个独立的、仅用于推理的版本,旨在实现分钟级多镜头音视频生成。它采用了经过蒸馏的DMD生成器、配对的跨模态记忆以及故事级别的一致性。其性能的核心在于,一个跨模态视听记忆库能够在长达五分钟的视频中保持角色外观和语音音色的一致性。同时,一个训练后处理流程将基于记忆的强化学习与分布匹配蒸馏相结合,实现了7.5倍的速度提升,显著增强了视觉质量和对齐效果。00
omega-aiOmega-AI:基于java打造的深度学习框架,帮助你快速搭建神经网络,实现模型推理与训练,引擎支持自动求导,多线程与GPU运算,GPU支持CUDA,CUDNN。Java03
llm-universe本项目是一个面向小白开发者的大模型应用开发教程,在线阅读地址:https://datawhalechina.github.io/llm-universe/Jupyter Notebook08
热门内容推荐
最新内容推荐
项目优选
收起
暂无描述
Dockerfile
759
4.94 K
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
853
1.91 K
deepin linux kernel
C
32
16
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
673
1.31 K
Ascend Extension for PyTorch
Python
716
866
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed.
Get Started
Rust
1.77 K
186
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
454
436
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.06 K
1.09 K
CANNBot 是面向 CANN 开发的用于提升开发效率的系列智能体,本仓库为其提供可复用的 Skills 模块。
Python
990
598
暂无简介
Dart
1 K
259