使用python实现短线选股

2023-10-09 19:20

本文主要是介绍使用python实现短线选股,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

经常做短线的朋友都知道,选股是个较为复杂的工作,尤其是像我们这种非职业选手,下面就分享一些通过python实现选股的思路。
在这里插入图片描述

股票信息获取

炒短线离不开龙虎榜,我们先来通过龙虎榜来进行股票选择

url = 'https://applhb.longhuvip.com/w1/api/index.php'headers = {'user-agent':'Mozilla/5.0(Linux; Android 7.1.2; SM-G955N Build/NRD90M.G955NKSU1AQDC; wv)'}# POST请求参数params = {'st': '500','Index': '0','c': 'LongHuBang','PhoneOSNew': 1,'a': 'GetStockList','DeviceID': '0f6ac4ae-370d-3091-a618-1d9dbb2ecce0','apiv': 'w31','Type': 2,'UserID': 0,'Token': 0,'Time': 0,}# 发送POST请求response = requests.post(url, params=params, headers=headers)# 将编码设置为当前编码response.encoding = response.apparent_encoding# 解析JSON数据data = json.loads(response.text)# 获取买入营业部、卖出营业部和风口概念等数据BIcon = data.get('BIcon')SIcon = data.get('SIcon')fkgn = data.get('fkgn')lb = data.get('lb')all_data_list = []# 遍历股票列表,提取数据for item in data.get('list'):ID = item.get('ID')item_data = [ID,item.get('Name'),item.get('IncreaseAmount'),item.get('BuyIn'),item.get('JoinNum'),','.join(BIcon.get(ID, [])),','.join(SIcon.get(ID, [])),','.join(fkgn.get(ID, {}).values()),lb.get(ID),]# 将数据转换成DataFrame类型sample_data = pd.DataFrame(item_data).Tcolumn_dict = {0: '股票代码',1: '股票名称',2: '涨幅',3: '净买入',4: '关联数',5: '买入营业部',6: '卖出营业部',7: '风口概念',8: '连板数'}sample_data.rename(columns=column_dict, inplace=True)all_data_list.append(sample_data)# 返回DataFrame类型数据all_data = pd.concat(all_data_list)

这个时候我们就拿到了我们想要的数据

     股票代码   股票名称  ...                                               风口概念   连板数
0  600895   张江高科  ...  光刻机,蚂蚁金服概念,芯片,上海,REITs,地产链,创投,中报增长,业绩增长,汽车类,新能源汽车  None
0  002194   武汉凡谷  ...  5G,滤波器,芯片,华为概念,人工智能,ST摘帽,武汉,教育,智能驾驶,毫米波雷达,通信,C...  None
0  000766   通化金马  ...  阿尔茨海默,医药,创新药,肝炎概念,中药,大麻,医美,民营医院,超跌,并购重组,中报增长,业绩增长     4
0  002229   鸿博股份  ...  英伟达概念,ChatGPT,虚拟人,服务器,元宇宙,华为概念,人工智能,海南,包装印刷,世界...  None

这个时候我们就拿到了龙虎榜的基础信息

进一步信息获取

龙虎榜上的信息有限,我们可以进一步获取到信息。

def get_dea_info(certificate_id):exchange_list = ['sh','sz',]now_time = get_now_time()year, month, date = now_time.split("-")start_month = month[-1] if "0" in month else monthstart_month = int(start_month) - 1start_month = str(start_month) if start_month > 9 else f"0{start_month}"end_date = f'{year}-{month}-{date}'start_date = f'{year}-{start_month}-{date}'print(start_date)print(end_date)have_search_info = Falsefor exchange in exchange_list:rs = bs.query_history_k_data(f"{exchange}.{certificate_id}","date,code,open,high,low,close,preclose,volume,amount,adjustflag,turn,tradestatus,pctChg,peTTM,pbMRQ,psTTM,pcfNcfTTM,isST",start_date=start_date,end_date=end_date,frequency="d", adjustflag="3")detail_data_list = []while (rs.error_code == '0') & rs.next():  # 获取一条记录,将记录合并在一起detail_data_list.append(rs.get_row_data())if detail_data_list:have_search_info = Truebreakif have_search_info:result = pd.DataFrame(detail_data_list, columns=rs.fields)for count_rs in ['open', 'high', 'low', 'close']:result[count_rs] = result.apply(lambda x: get_percentage(x, count_rs), axis=1)result['turn'] = result['turn'].apply(lambda x: x[:5])result = result.sort_values(by='date', ascending=False)return result

这样我们就拿到了个股最新一个月的量价信息

          date       code  open   high  ...     pbMRQ     psTTM  pcfNcfTTM isST
21  2023-09-15  sz.002889  5.74  10.02  ...  2.256259  1.842298  21.709520    0
20  2023-09-14  sz.002889 -1.19  10.02  ...  2.050822  1.674554  19.732829    0
19  2023-09-13  sz.002889 -3.15   0.53  ...  1.863981  1.521993  17.935063    0
18  2023-09-12  sz.002889  0.55   6.99  ...  1.855126  1.514763  17.849860    0
17  2023-09-11  sz.002889  0.92   1.26  ...  1.786057  1.458366  17.185283    0
16  2023-09-08  sz.002889  0.96   9.99  ...  1.832989  1.496687  17.636855    0
15  2023-09-07  sz.002889 -0.05  -0.05  ...  1.666514  1.360756  16.035054    0

策略书写

后面就是策略选股了
比如我们要进行选股了,我们想做连板票,我们搜素一下未放量,且最近一个月没有前高的票

def search_strategy_result(sample_data):# 我们筛选涨停票, 且没有放巨量, 之前也未放过巨量的recently = sample_data.iloc[0]# 判断当天是否涨停close = float(recently['close'])if float(recently['pctChg']) < 9.6:return False# 判断一个月内是否有前高max_high = float(sample_data['high'].max())if close < max_high:return False# 判断换手率是否超过15if float(recently['turn']) > 15.0:return False# 相比前一天是否放量turn_ration = float(recently['turn']) / float(sample_data.iloc[1]['turn'])if turn_ration > 1.5:return Falsereturn True

结果

通化金马  000766 符合策略已入库
东方嘉盛  002889 符合策略已入库
泉阳泉  600189 符合策略已入库
龙江交通  601188 符合策略已入库
路桥信息 未查询到信息
2023-09-17龙虎榜共有43只股票4只股票符合要求

本文章只是技术分享,不能作为投资建议

这篇关于使用python实现短线选股的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/175032

相关文章

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

基于Python打造一个智能单词管理神器

《基于Python打造一个智能单词管理神器》这篇文章主要为大家详细介绍了如何使用Python打造一个智能单词管理神器,从查询到导出的一站式解决,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 项目概述:为什么需要这个工具2. 环境搭建与快速入门2.1 环境要求2.2 首次运行配置3. 核心功能使用指

Python实现微信自动锁定工具

《Python实现微信自动锁定工具》在数字化办公时代,微信已成为职场沟通的重要工具,但临时离开时忘记锁屏可能导致敏感信息泄露,下面我们就来看看如何使用Python打造一个微信自动锁定工具吧... 目录引言:当微信隐私遇到自动化守护效果展示核心功能全景图技术亮点深度解析1. 无操作检测引擎2. 微信路径智能获

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

redis中使用lua脚本的原理与基本使用详解

《redis中使用lua脚本的原理与基本使用详解》在Redis中使用Lua脚本可以实现原子性操作、减少网络开销以及提高执行效率,下面小编就来和大家详细介绍一下在redis中使用lua脚本的原理... 目录Redis 执行 Lua 脚本的原理基本使用方法使用EVAL命令执行 Lua 脚本使用EVALSHA命令

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

利用Python打造一个Excel记账模板

《利用Python打造一个Excel记账模板》这篇文章主要为大家详细介绍了如何使用Python打造一个超实用的Excel记账模板,可以帮助大家高效管理财务,迈向财富自由之路,感兴趣的小伙伴快跟随小编一... 目录设置预算百分比超支标红预警记账模板功能介绍基础记账预算管理可视化分析摸鱼时间理财法碎片时间利用财

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B

Python中的Walrus运算符分析示例详解

《Python中的Walrus运算符分析示例详解》Python中的Walrus运算符(:=)是Python3.8引入的一个新特性,允许在表达式中同时赋值和返回值,它的核心作用是减少重复计算,提升代码简... 目录1. 在循环中避免重复计算2. 在条件判断中同时赋值变量3. 在列表推导式或字典推导式中简化逻辑