A股历史与实时行情数据统一接入、清洗与存储
Project description
hqdata - A股历史与实时行情数据统一接入、清洗与存储
定位
hqdata 是 HonestQuant 量化系统的数据基础层,职责边界清晰:
- 对下:封装各数据源 SDK,屏蔽接口差异
- 对上:提供统一的查询接口
- 上层策略和引擎只调用
hqdata.api,不直接接触任何数据源
支持的主要功能
| 功能 | API | tushare | ricequant | 说明 |
|---|---|---|---|---|
| 交易日历 | get_calendar |
✓ | ✓ | |
| 股票列表 | get_stock_list |
✓ | ✓ | 返回当日上市状态的股票基本信息 |
| 股票实时快照 | get_stock_snapshot |
✓ | ✓ | 含5档盘口 |
| 股票日线 | get_stock_daily_bar |
✓ | ✓ | |
| 股票分钟线 | get_stock_minute_bar |
✗ | ✓ | |
| 指数列表 | get_index_list |
✓ | ✓ | 默认返回 SSE、SZSE 指数 |
| 指数日线 | get_index_daily_bar |
✓ | ✓ | |
| 指数分钟线 | get_index_minute_bar |
✗ | ✓ |
另有更多功能,可以前往api.py查看所有功能。
支持的数据源
| 数据源 | 状态 | 说明 |
|---|---|---|
| tushare | 已接入 | 需满足账户2000积分, 部分功能需独立权限 |
| ricequant | 已接入 | 需license,试用请前往官网申请权限 |
| AKShare | 计划中 | 免费,实时数据 |
| 迅投 | 计划中 | 需迅投终端 |
| iTick | 计划中 | 需注册 |
安装
方式一:通过pip安装
# 基础安装(仅包含核心功能)
pip install hqdata
# 按需安装数据源依赖
pip install hqdata[tushare] # tushare 支持
pip install hqdata[ricequant] # ricequant 支持
pip install hqdata[tushare,ricequant] # 同时安装两者
# 复制模板并自行填入所需字段
cp .env.example .env # 放在你运行 Python 代码的当前目录(优先)/包安装目录
方式二:本地开发
# 创建虚拟环境
python -m venv .venv
source .venv/bin/activate
# 安装依赖 (editable 模式,改代码直接生效)
pip install -e .
# 复制模板并自行填入所需字段
cp .env.example .env # 放在你运行 Python 代码的当前目录(优先)/包安装目录
使用
以 tushare/ricequant为例 为例:
import hqdata
hqdata.init_source("tushare")
hqdata.get_stock_list() # 查询当日股票列表(上市状态)
命令行工具
安装后可直接使用 hqdata 命令从数据源拉取数据并按日期存储为 CSV 文件。
hqdata [--source SOURCE] [--output DIR] COMMAND [options]
| 参数 | 说明 | 默认值 |
|---|---|---|
--source |
数据源,逗号分隔 | tushare |
--output |
输出根目录 | ~/.hqdata |
使用子命令和 --help 可查看具体用法
测试
pytest tests/ -v # 运行全部测试
pytest tests/test_calendar.py::TestTradingCalendar::test_is_trading_day # 运行单个测试
参数说明
输入
symbol(股票代码)
symbol 参数统一使用 交易所简写代码 作为后缀,支持以 , 分隔的多个symbol传入
| 交易所 | 交易所简写代码 | symbol示例 |
|---|---|---|
| 上交所 | SH | "600000.SH" |
| 深交所 | SZ | "000001.SZ" |
start_date / end_date(日期区间)
日期格式为 YYYYMMDD 的str,如 "20260401" 表示 2026年4月1日。
start_date:开始日期(包含)end_date:结束日期(包含)
frequency(频率)
| 值 | 说明 | 支持源 |
|---|---|---|
| "1m" | 1分钟线 | ricequant |
| "5m" | 5分钟线 | ricequant |
| "15m" | 15分钟线 | ricequant |
| "30m" | 30分钟线 | ricequant |
| "60m" | 60分钟线 | ricequant |
exchange(交易所)
| 代码 | 说明 |
|---|---|
| "SSE" | 上海证券交易所 |
| "SZSE" | 深圳证券交易所 |
| "BSE" | 北京证券交易所 |
is_open(是否交易日)
| 值 | 说明 |
|---|---|
| None | 返回所有自然日(默认) |
| True | 只返回交易日 |
| False | 只返回非交易日 |
board(股票板块)
| 值 | 说明 |
|---|---|
| "MB" | 主板 |
| "GEM" | 创业板 |
| "STAR" | 科创板 |
| "BJSE" | 北交所 |
market(指数市场)
market未指定时,默认为"SSE,SZSE",即只返回上交所和深交所的指数
| 值 | 说明 | 支持源 |
|---|---|---|
| "CSI" | 中证指数 | tushare |
| "CICC" | 中金指数 | tushare |
| "SSE" | 上交所指数 | tushare,ricequant |
| "SZSE" | 深交所指数 | tushare,ricequant |
| "BJSE" | 北交所指数 | ricequant |
| "SW" | 申万指数 | tushare |
| "MSCI" | MSCI 指数 | tushare |
| "OTH" | 其他指数 | tushare |
特性说明:
- tushare将北交所指数归类到了OTH中
- ricequant除了3个交易所指数,其他指数的market为NaN
输出参数说明
volume(成交量)
单位:手(lots,1手=100股,科创板1手=200股)
turnover(成交额)
单位:元(yuan)
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file hqdata-0.1.15.tar.gz.
File metadata
- Download URL: hqdata-0.1.15.tar.gz
- Upload date:
- Size: 27.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6957f28c053801dfb524d907045e6ed4df6206a472ce32f1e73b7b5e7dae0bde
|
|
| MD5 |
04a92f4f35ae24853327cda9b3228c0b
|
|
| BLAKE2b-256 |
ad06265568bea8b810e7467dfd180c7fcfb3f713528787abbda2be697a73a3f1
|
File details
Details for the file hqdata-0.1.15-py3-none-any.whl.
File metadata
- Download URL: hqdata-0.1.15-py3-none-any.whl
- Upload date:
- Size: 21.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d491771ca833b2e3f5cd709b8bb9ee6a62433cb020c7577e81393e60cb951c86
|
|
| MD5 |
5b5b37206cd93c5e22b42bd0e67dbc1e
|
|
| BLAKE2b-256 |
b42de21cc46c60cbf2e9e307cf56c855b8bcfcbb033f915712c62afe5bf3d938
|