如何精准识别并标记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全文检索【实战】