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

手把手教你用miniqmt获取沪深A股小市值股票清单(附完整Python代码)

手把手教你用miniqmt构建小市值股票筛选系统在量化投资领域小市值效应一直是备受关注的市场异象。大量实证研究表明长期来看小市值股票组合往往能够跑赢大盘。对于想要尝试量化策略的初学者来说构建一个可靠的小市值股票筛选系统是迈入实战的第一步。本文将详细介绍如何利用miniqmt这一轻量级量化工具从数据获取到策略实现打造属于自己的小市值股票筛选器。1. 环境准备与miniqmt基础配置在开始之前我们需要确保Python环境已经正确配置。推荐使用Python 3.8或以上版本这是大多数量化平台兼容性最好的版本。创建一个干净的虚拟环境是个好习惯python -m venv miniqmt_env source miniqmt_env/bin/activate # Linux/Mac # 或者 .\miniqmt_env\Scripts\activate # Windows接下来安装必要的依赖包。miniqmt通常作为量化平台的Python SDK提供我们需要先安装其核心包pip install miniqmt pip install pandas numpy # 数据处理必备库配置miniqmt连接时通常需要设置账号信息。这里我们创建一个配置文件config.py来管理这些敏感信息# config.py ACCOUNT your_account_id TOKEN your_access_token SERVER trade_server_address注意在实际项目中建议使用环境变量或加密方式存储敏感信息不要将账号密码直接硬编码在脚本中。2. 获取沪深A股基础数据小市值策略的第一步是获取全市场股票列表。miniqmt提供了便捷的接口获取各类板块成分股import miniqmt as mq from config import ACCOUNT, TOKEN, SERVER # 初始化连接 xt mq.Trade(ACCOUNT, TOKEN, SERVER) # 获取沪深A股全量股票列表 sector_stocks xt.get_stock_list_in_sector(沪深A股) print(f获取沪深A股股票共{len(sector_stocks)}只)这个列表包含了市场上所有需要关注的股票代码但我们需要更多信息来计算市值。市值计算的基本公式是市值 流通股本 × 当前股价miniqmt的get_instrument_detail接口可以获取股票的详细信息def get_stock_details(stock_code): 获取单只股票的详细信息 detail xt.get_instrument_detail(stock_code) return { code: detail[InstrumentID], name: detail[InstrumentName], float_volume: detail.get(FloatVolume), # 流通股本(股) price: detail.get(SettlementPrice) # 最新价 }3. 市值计算与异常数据处理实际数据获取过程中我们需要处理各种异常情况。以下是常见的异常数据场景及处理方法异常类型检测方法处理方式停牌股票最新价为0或None从候选池中排除新股/次新股流通股本数据缺失根据上市日期判断是否排除数据不完整关键字段为None记录日志并跳过极端值市值超出合理范围设置阈值过滤实现一个健壮的市值计算函数import pandas as pd def calculate_market_values(stock_list): 计算股票市值并处理异常 valid_stocks [] for code in stock_list: try: detail get_stock_details(code) if not detail[float_volume] or not detail[price]: continue # 转换为亿为单位 market_cap (detail[float_volume] * detail[price]) / 1e8 if 0 market_cap 500: # 过滤异常大市值和无效数据 valid_stocks.append({ code: code, name: detail[name], market_cap: round(market_cap, 2), price: detail[price] }) except Exception as e: print(f处理{code}时出错: {str(e)}) return pd.DataFrame(valid_stocks)4. 构建小市值股票组合有了市值数据后我们可以按照市值排序筛选出目标股票。通常小市值策略会关注以下几个维度绝对市值大小选择全市场市值最小的N只股票行业中性在各行业内选择相对小市值的股票流动性筛选确保入选股票有足够交易量以下是实现代码def build_small_cap_portfolio(df, top_n50, min_turnover0.5): 构建小市值组合 # 按市值升序排序 df_sorted df.sort_values(market_cap, ascendingTrue) # 简单选取前top_n只 portfolio df_sorted.head(top_n).copy() # 添加基础分析指标 portfolio[pe] portfolio.apply( lambda x: xt.get_pe_ratio(x[code]), axis1) portfolio[turnover] portfolio.apply( lambda x: xt.get_turnover_rate(x[code]), axis1) # 流动性筛选 portfolio portfolio[portfolio[turnover] min_turnover] return portfolio.reset_index(dropTrue)5. 策略回测与优化建议构建好小市值组合后我们需要评估其历史表现。miniqmt提供了基础的回测功能def backtest_portfolio(portfolio, start_date, end_date): 简单回测组合表现 results [] for code in portfolio[code]: hist_data xt.get_history( code, startstart_date, endend_date, fields[close, volume] ) if not hist_data.empty: ret (hist_data[close][-1] - hist_data[close][0]) / hist_data[close][0] results.append(ret) return pd.Series(results).describe()在实际应用中小市值策略还可以从以下几个方向优化多因子增强结合估值、动量等因子提高胜率动态调仓根据市场状态调整持仓周期风险控制设置止损机制和最大回撤限制# 多因子筛选示例 def multi_factor_screen(df): 简单的多因子筛选 # 计算各因子Z-score df[value_z] (df[pe] - df[pe].mean()) / df[pe].std() df[momentum_z] (df[1m_return] - df[1m_return].mean()) / df[1m_return].std() # 综合打分 df[score] -0.5*df[value_z] 0.3*df[momentum_z] - 0.2*df[market_cap_z] return df.sort_values(score, ascendingFalse)6. 完整代码实现与部署将上述模块整合成一个完整的策略脚本# small_cap_strategy.py import pandas as pd import miniqmt as mq from config import ACCOUNT, TOKEN, SERVER class SmallCapStrategy: def __init__(self): self.xt mq.Trade(ACCOUNT, TOKEN, SERVER) def get_universe(self): 获取初始股票池 return self.xt.get_stock_list_in_sector(沪深A股) def calculate_market_cap(self, stock_list): 计算市值 # 实现同前... pass def build_portfolio(self, df, top_n30): 构建组合 # 实现同前... pass def run(self): 执行策略 universe self.get_universe() mc_df self.calculate_market_cap(universe) portfolio self.build_portfolio(mc_df) # 保存结果 portfolio.to_csv(small_cap_portfolio.csv, indexFalse) print(f生成包含{len(portfolio)}只股票的小市值组合) return portfolio if __name__ __main__: strategy SmallCapStrategy() strategy.run()对于生产环境部署建议采用以下架构small_cap_strategy/ ├── config/ # 配置文件 ├── data/ # 数据存储 ├── logs/ # 日志文件 ├── src/ # 源代码 │ ├── strategy.py # 策略核心 │ ├── utils.py # 工具函数 │ └── backtest.py # 回测模块 └── requirements.txt # 依赖清单在实际使用中我发现小市值策略在震荡市中表现尤为突出但在极端行情下波动较大。一个实用的技巧是将小市值因子与其他低相关性的因子结合比如加入质量因子或波动率筛选可以有效平滑收益曲线。另外定期检查数据质量也很重要特别是在财报季前后流通股本数据可能会有较大变化。

相关文章:

手把手教你用miniqmt获取沪深A股小市值股票清单(附完整Python代码)

手把手教你用miniqmt构建小市值股票筛选系统 在量化投资领域,小市值效应一直是备受关注的市场异象。大量实证研究表明,长期来看小市值股票组合往往能够跑赢大盘。对于想要尝试量化策略的初学者来说,构建一个可靠的小市值股票筛选系统是迈入实…...

Video2X视频增强技术全解析:从入门到专家的进阶指南

Video2X视频增强技术全解析:从入门到专家的进阶指南 【免费下载链接】video2x A lossless video/GIF/image upscaler achieved with waifu2x, Anime4K, SRMD and RealSR. Started in Hack the Valley II, 2018. 项目地址: https://gitcode.com/GitHub_Trending/vi…...

寻音捉影·侠客行惊艳效果:暗号支持同义词扩展(如‘钱’→‘费用’‘预算’‘成本’)

寻音捉影侠客行惊艳效果:暗号支持同义词扩展 在茫茫音海中寻找特定的只言片语,如同在大漠中寻觅一枚绣花针。寻音捉影侠客行是一位拥有"顺风耳"的音频处理工具,只需你定下"暗号",它便能在瞬息之间为你锁定目…...

RMBG-2.0异常处理指南:常见错误分析与解决

RMBG-2.0异常处理指南:常见错误分析与解决 1. 引言 遇到RMBG-2.0抠图时出现各种报错和异常?别担心,这是每个开发者都会经历的过程。无论是环境配置问题、显存不足,还是模型加载失败,这些看似棘手的问题其实都有对应的…...

ollama部署embeddinggemma-300m:支持离线运行的多语言嵌入服务搭建教程

ollama部署embeddinggemma-300m:支持离线运行的多语言嵌入服务搭建教程 1. 引言:为什么选择embeddinggemma-300m 如果你正在寻找一个既小巧又强大的文本嵌入模型,embeddinggemma-300m绝对值得关注。这个由谷歌推出的开源模型只有3亿参数&am…...

NEURAL MASK 数据库集成实战:管理海量图像处理任务与结果

NEURAL MASK 数据库集成实战:管理海量图像处理任务与结果 想象一下,你搭建了一个很酷的在线图像处理服务,用户上传一张照片,选择“换背景”或者“智能修复”,几秒钟后就能拿到处理好的图片。刚开始用户不多&#xff0…...

YOLO开发环境一站式配置指南:基于阿里源的快速部署方案

1. 为什么选择阿里源配置YOLO环境 第一次尝试在本地搭建YOLO开发环境时,我花了整整两天时间卡在依赖安装环节。不是下载速度慢到令人崩溃,就是各种版本冲突导致安装失败。后来发现使用国内镜像源可以完美解决这些问题,特别是阿里云的PyPI镜像…...

Trento遥感数据集获取与预处理全指南

1. Trento遥感数据集简介 Trento数据集是遥感图像分析领域常用的公开数据集之一,主要包含意大利特伦托地区的高分辨率遥感影像。这个数据集特别适合用于土地覆盖分类、目标检测和语义分割等计算机视觉任务。我第一次接触这个数据集是在做一个农业用地分类项目时&…...

R语言实战:如何用TwosampleMR和MRlap包搞定孟德尔随机化分析(附完整代码)

R语言实战:用TwosampleMR和MRlap包完成孟德尔随机化全流程分析 孟德尔随机化(Mendelian Randomization, MR)已成为生物信息学研究中探索因果关系的重要工具。对于R语言用户而言,如何高效整合TwosampleMR和MRlap这两个互补性极强的…...

抛弃U盘!用AListFlutter把旧手机改造成无线网盘服务器(支持电视投屏)

抛弃U盘!用AListFlutter把旧手机改造成无线网盘服务器(支持电视投屏) 每次整理家庭影音资源时,最头疼的就是在不同设备间来回拷贝文件。U盘传输速度慢、容量有限,而公有云盘又受限于会员体系和隐私风险。其实你抽屉里那…...

颠覆级EFI配置效率革命:OpCore Simplify如何终结黑苹果折腾时代

颠覆级EFI配置效率革命:OpCore Simplify如何终结黑苹果折腾时代 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 你是否也曾在黑苹果配置的…...

软件工程入门:面向数据流的设计方法在电商系统中的应用

软件工程实战:用数据流图构建高可维护性电商系统 在当今快速迭代的互联网产品开发中,如何将软件工程理论有效落地成为开发者的核心挑战。面向数据流的设计方法(Data Flow-Oriented Design)作为结构化设计的经典范式,特…...

MobaXterm进阶指南:解锁Windows下SSH与X11的协同效能

1. 为什么你需要MobaXterm? 作为一个常年需要在Windows和Linux之间切换的开发者,我试过无数终端工具,最后发现MobaXterm才是真正的"瑞士军刀"。它不仅是一个SSH客户端,更是一个完整的远程工作环境解决方案。想象一下&am…...

Windows11下利用OpenOCD与FT2232H实现FPGA的JTAG调试全攻略

1. 环境准备:驱动与工具安装 在Windows11下玩转FPGA调试,首先得搞定FT2232H这块多功能芯片。我当初第一次接触这块芯片时,被它既能当USB转串口又能做JTAG调试器的特性惊艳到了。不过要让它在JTAG模式下正常工作,得先过驱动安装这一…...

三相无刷电机控制进阶:从六步换向到FOC的实战解析

1. 三相无刷电机控制技术概述 第一次接触三相无刷电机时,很多人都会被它复杂的控制方式吓到。但如果你拆开一个普通电脑风扇,就会发现里面藏着的就是这种神奇的小东西。与传统的直流有刷电机相比,无刷电机通过电子换向取代了机械电刷&#xf…...

Gemma-3 Pixel Studio应用场景:博物馆文物照片年代判断+风格溯源分析

Gemma-3 Pixel Studio应用场景:博物馆文物照片年代判断风格溯源分析 1. 引言:当AI遇见千年文物 想象一下,你是一位博物馆的研究员,面对着一批新入库的、信息模糊的文物照片。它们可能来自民间捐赠,可能来自考古现场&…...

安防开发者必看:如何用视频中间件统一接入大华/海康设备(含Ehome/主动注册协议对比)

安防开发者必看:如何用视频中间件统一接入大华/海康设备(含Ehome/主动注册协议对比) 在智慧城市建设和连锁门店管理等场景中,安防设备的多品牌混合组网已成为常态。作为开发者,我们常常需要同时对接大华、海康等不同厂…...

OSA插件避坑指南:从MultiplePrefabs案例看Unity无限列表开发技巧

OSA插件避坑指南:从MultiplePrefabs案例看Unity无限列表开发技巧 在Unity开发中,处理大量数据列表展示是个常见挑战。UGUI自带的ScrollView在面对成百上千个元素时,性能问题会变得尤为明显。Optimized ScrollView Adapter(OSA&…...

BGP面试必问:路由聚合与多宿主网络实战避坑指南(附配置示例)

BGP面试必问:路由聚合与多宿主网络实战避坑指南(附配置示例) 在当今复杂的网络架构中,BGP(边界网关协议)作为互联网的"粘合剂",其重要性不言而喻。无论是准备网络工程师面试的求职者&…...

TensorFlow-v2.15镜像使用指南:Jupyter Lab交互式开发,让AI学习更简单

TensorFlow-v2.15镜像使用指南:Jupyter Lab交互式开发,让AI学习更简单 1. 引言 1.1 为什么选择TensorFlow-v2.15镜像? 如果你刚开始接触深度学习,或者厌倦了在本地电脑上反复折腾Python环境、CUDA驱动和各种依赖包,…...

终极指南:基于多智能体LLM的TradingAgents-CN金融交易框架全面解析

终极指南:基于多智能体LLM的TradingAgents-CN金融交易框架全面解析 【免费下载链接】TradingAgents-CN 基于多智能体LLM的中文金融交易框架 - TradingAgents中文增强版 项目地址: https://gitcode.com/GitHub_Trending/tr/TradingAgents-CN TradingAgents-CN…...

Qwen3-VL-WEB镜像实测:上传图片就能对话的AI有多好用?

Qwen3-VL-WEB镜像实测:上传图片就能对话的AI有多好用? 1. 前言:当AI学会“看图说话” 想象一下,你拍了一张工作现场的图片,AI不仅能告诉你图片里有什么,还能分析出潜在的安全隐患。或者,你上传…...

ChatGPT对话时间监控:从原理到实践的完整解决方案

在构建基于大语言模型的对话应用时,除了关注回复内容的质量,对话过程的精细化管理同样至关重要。其中,对话时间监控是一个容易被忽视但实际影响深远的技术点。它不仅是简单的计时,更是实现精准计费、优化用户体验、保障系统稳定性…...

SiameseAOE中文-base实战手册:ABSA结果后处理——情感极性标准化与业务标签映射

SiameseAOE中文-base实战手册:ABSA结果后处理——情感极性标准化与业务标签映射 1. 理解ABSA结果后处理的必要性 当你使用SiameseAOE模型进行属性情感分析后,可能会遇到这样的情况:模型输出的情感词五花八门,比如"很满意&q…...

StructBERT扩展应用:小说情感脉络分析工具开发

StructBERT扩展应用:小说情感脉络分析工具开发 1. 引言 你有没有读过一本小说后,感觉整个故事的情感起伏特别精彩,但却说不清楚具体是怎么变化的?或者作为文学研究者,想要量化分析一部作品的情感发展脉络&#xff1f…...

人脸分析系统从零到一:手把手教你部署智能检测工具

人脸分析系统从零到一:手把手教你部署智能检测工具 1. 从想法到现实:为什么你需要这个工具 想象一下这个场景:你手头有一批用户上传的头像照片,需要快速统计用户的年龄分布和性别比例,为产品设计提供数据支持。传统做…...

5分钟搞定Gemini CLI与MCP服务器集成:从零配置到实战应用

5分钟搞定Gemini CLI与MCP服务器集成:从零配置到实战应用 如果你是一名开发者,正寻找一种快速将AI能力融入本地工作流的方法,Gemini CLI与MCP服务器的组合可能是你需要的解决方案。这套工具组合能让你的终端直接调用AI模型,并通过…...

Shardingsphere-Proxy 5.5.0实战:从零配置到Navicat连接的全流程指南

Shardingsphere-Proxy 5.5.0实战:从零配置到Navicat连接的全流程指南 在分布式数据库架构中,Shardingsphere-Proxy作为透明化的数据库代理层,能够将分库分表的复杂性对应用完全隐藏。本文将带您完成从环境准备到可视化工具连接的完整落地流程…...

从User-Agent到行为指纹:现代爬虫攻防中的身份伪装与检测博弈

1. 爬虫身份伪装的基础:User-Agent与请求头 十年前我刚入行时,网站反爬还停留在"看脸"阶段——服务器只认User-Agent这个"身份证"。当时用Python的requests库随手改个浏览器UA就能畅通无阻。但现在的反爬系统早已进化成"刑侦专…...

MCP SDK性能衰减真相:跨语言序列化耗时飙升370%的4个隐蔽根源及优化对照表

第一章:MCP跨语言SDK性能衰减问题全景认知MCP(Microservice Communication Protocol)跨语言SDK在多语言微服务协同场景中广泛部署,但实践中普遍观测到显著的性能衰减现象——相同逻辑在Go原生实现中耗时约0.8ms,而经Py…...