如何精准识别并标记K线图中首次突破的枢轴点(仅标记一次)
发布时间 - 2026-01-23 00:00:00 点击率:次本文介绍如何使用Pandas和NumPy高效识别K线数据中的局部极值枢轴点(5窗口中心滚动),并确保每个高点/低点仅被标记一次,避免重复触发,适用于量化交易中的关键价格位识别。
在技术分析中,枢轴点(Pivot Points)常用于识别潜在的支撑位与阻力位。一个稳健的枢轴点检测逻辑是:某根K线的high为其中心±2根K线共5根内的最高值,则标记为高位枢轴(值=2);其low为该窗口内最低值,则标记为低位枢轴(值=1);否则为0。关键在于——每个枢轴点仅应被识别一次,即满足条件的首个匹配位置,而非所有满足条件的行(尤其当连续多根K线价格相同时易误标)。
Pandas 的 rolling(..., center=True) 配合布尔条件判断,天然支持这种“中心对齐+局部极值”逻辑。以下为完整实现:
import pandas as pd
import numpy as np
# 示例数据构建
data = {
'date': ['01.01.2025', '02.01.2025', '03.01.2025', '04.01.2025', '05.01.2025',
'06.01.2025', '07.01.2025', '08.01.2025', '09.01.2025', '10.01.2025',
'11.01.2025', '12.01.2025', '13.01.2025', '14.01.2025', '15.01.2025',
'16.01.2025', '17.01.2025'],
'high': [207, 208, 209, 207, 206, 205, 204, 206, 207, 208, 210, 212, 214, 207, 203, 201, 199],
'low': [204, 205, 205, 203, 202, 200, 199, 201, 202, 205, 207, 209, 210, 204, 202, 198, 196]
}
df = pd.DataFrame(data)
# ✅ 核心逻辑:5期中心滚动,识别唯一枢轴点
cond_high = df['high'].rolling(5, center=True).max().eq(df[
'high']) # 高点是否为窗口内最大
cond_low = df['low'].rolling(5, center=True).min().eq(df['low']) # 低点是否为窗口内最小
# 使用 np.select 实现三值映射:高点→2,低点→1,其余→0
df['pivot'] = np.select([cond_high, cond_low], [2, 1], default=0)
# ⚠️ 注意:rolling(center=True) 在边界处会生成 NaN,需填充或丢弃
# 推荐做法:用 dropna() 或 fillna(0) 处理首尾两行(因窗口不完整)
df['pivot'] = df['pivot'].fillna(0).astype(int) # 确保类型为整数运行后,df['pivot'] 将准确标记:
- 209(03.01)为前5根K线最高价 → pivot = 2
- 199(07.01)为前5根K线最低价 → pivot = 1
- 214(13.01)为新高 → pivot = 2
- 后续无其他满足条件的极值 → 其余为0
✅ 为何“仅一次”?
因为 rolling(5, center=True).max().eq(df['high']) 是逐行严格比较:仅当当前 high 恰好等于以它为中心的5期滚动最大值时才为 True。即使后续几根K线价格相同,只要它们不构成新的5期窗口极值(例如被更高/更低价格覆盖),就不会被重复标记——这天然保证了每个枢轴点的唯一性与首次性。
? 进阶提示:
- 若需排除平台震荡导致的连续相同极值,可叠加 diff().ne(0) 过滤相邻重复;
- 实盘中建议结合成交量、波动率过滤假突破;
- 时间序列需确保已按 date 升序排序,否则滚动窗口将错位。
该方法简洁、向量化、无显式循环,兼顾性能与可读性,是量化策略中枢轴点信号生成的标准实践。
# numpy
# pandas
# date
# 循环
# 进阶
# 升序
# 首次
# 适用于
# 更高
# 布尔
# 为其
# 而非
# 首个
# 时才
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel如何生成API文档?(Swagger/OpenAPI教程)
html5audio标签播放结束怎么触发事件_onended回调方法【教程】
如何在阿里云高效完成企业建站全流程?
Laravel如何使用.env文件管理环境变量?(最佳实践)
简历没回改:利用AI润色让你的文字更专业
Windows10如何更改计算机工作组_Win10系统属性修改Workgroup
如何用PHP快速搭建CMS系统?
如何彻底删除建站之星生成的Banner?
手机软键盘弹出时影响布局的解决方法
Linux系统命令中screen命令详解
Laravel如何生成和使用数据填充?(Seeder和Factory示例)
什么是javascript作用域_全局和局部作用域有什么区别?
EditPlus 正则表达式 实战(3)
如何在服务器上三步完成建站并提升流量?
Java垃圾回收器的方法和原理总结
广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?
Laravel如何实现图片防盗链功能_Laravel中间件验证Referer来源请求【方案】
canvas 画布在主流浏览器中的尺寸限制详细介绍
Laravel策略(Policy)如何控制权限_Laravel Gates与Policies实现用户授权
Laravel如何监控和管理失败的队列任务_Laravel失败任务处理与监控
如何在IIS管理器中快速创建并配置网站?
java中使用zxing批量生成二维码立牌
移动端脚本框架Hammer.js
ChatGPT怎么生成Excel公式_ChatGPT公式生成方法【指南】
如何在香港服务器上快速搭建免备案网站?
lovemo网页版地址 lovemo官网手机登录
昵图网官方站入口 昵图网素材图库官网入口
Laravel如何实现文件上传和存储?(本地与S3配置)
Laravel Telescope怎么调试_使用Laravel Telescope进行应用监控与调试
如何用AWS免费套餐快速搭建高效网站?
微信小程序 canvas开发实例及注意事项
javascript中的数组方法有哪些_如何利用数组方法简化数据处理
太平洋网站制作公司,网络用语太平洋是什么意思?
JavaScript如何操作视频_媒体API怎么控制播放
UC浏览器如何切换小说阅读源_UC浏览器阅读源切换【方法】
如何快速生成专业多端适配建站电话?
香港服务器部署网站为何提示未备案?
logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?
网站制作壁纸教程视频,电脑壁纸网站?
如何在不使用负向后查找的情况下匹配特定条件前的换行符
Laravel事件监听器怎么写_Laravel Event和Listener使用教程
INTERNET浏览器怎样恢复关闭标签页_INTERNET浏览器标签恢复快捷键与方法【指南】
jimdo怎样用html5做选项卡_jimdo选项卡html5实现与切换效果【指南】
标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南
如何快速搭建FTP站点实现文件共享?
如何获取PHP WAP自助建站系统源码?
Laravel怎么使用Intervention Image库处理图片上传和缩放
Laravel怎么使用Collection集合方法_Laravel数组操作高级函数pluck与map【手册】
小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?
Laravel怎么实现搜索高亮功能_Laravel结合Scout与Algolia全文检索【实战】
上一篇:notepad函数列表调不出来了
下一篇:notepad++找不到文件目录
上一篇:notepad函数列表调不出来了
下一篇:notepad++找不到文件目录


