Python 实现股票指标计算——WR

WR - 威廉指标

1 公式

威廉指标的计算公式为:

其中:

𝐻𝑛​ 是过去n日内的最高价。

𝐿𝑛​ 是过去n日内的最低价。

𝐶 是当前收盘价。

2 数据准备

我们以科创50指数 000688 为例,指数开始日期为2019-12-31,数据格式如下:

3 计算过程

python 复制代码
def wr(df: pd.DataFrame, N=10) -> pd.DataFrame:
    """
    计算威廉指标(Williams %R)并处理可能的除零错误.

    参数:
    ----------
    df : pd.DataFrame
        包含至少 'high', 'low' 和 'close' 列的DataFrame,分别表示每个周期的最高价、最低价和收盘价。

    N : int, 可选
        用于计算滚动窗口的周期数,默认值为10。

    返回值:
    -------
    data : pd.DataFrame
        原始DataFrame加上'Hn'(周期内最高价)、'Ln'(周期内最低价)和'WR'(威廉指标)三列。
    """

    # 创建一个df的副本以避免修改原始数据
    data = df.copy()

    # 使用rolling方法计算N周期内的最高价
    data['Hn'] = data['high'].rolling(N).max()

    # 使用rolling方法计算N周期内的最低价
    data['Ln'] = data['low'].rolling(N).min()

    # 获取浮点数的最小正数值,以防分母为零
    epsilon = np.finfo(float).eps

    # 计算威廉指标(Williams %R)
    # 公式为:(Hn - close) / (Hn - Ln) * 100
    # 在分母中加入epsilon以避免除零错误
    data['WR'] = (data['Hn'] - data['close']) / (data['Hn'] - data['Ln'] + epsilon) * 100

    # 返回包含计算结果的新DataFrame
    return data

4 注意事项

WR计算结果与东方财富软件中的值一致,与雪球中的值有差异。

相关推荐
喆星时瑜15 分钟前
ComfyUI本地部署Stable Diffusion:核心组件(Python、PyTorch、CUDA)版本与显卡配置全指南
pytorch·python·stable diffusion
大佬,救命!!!26 分钟前
定时打印的练习整理
linux·服务器·python·学习笔记·学习方法·定时发送
南棱笑笑生31 分钟前
20251028在荣品RD-RK3588-MID开发板的Android13系统下解决关机的时候最近打开的应用不关的问题
开发语言·python·rockchip
红树林0739 分钟前
BeautifulSoup 的页面中需要获取某个元素的 xpath 路径
前端·python·网络爬虫·beautifulsoup
jieyu11191 小时前
Python 实战:Web 漏洞 Python POC 代码及原理详解(1)
python·web安全
QQLOVEYY1 小时前
Python和PyCharm的安装教程
python·pycharm
想名字好难啊竟然不止我一个2 小时前
清除 Pip 缓存, 释放磁盘空间
python·缓存·pip
Eiceblue2 小时前
Python 快速提取扫描件 PDF 中的文本:OCR 实操教程
vscode·python·ocr·1024程序员节
APIshop2 小时前
淘宝/天猫 API 接口深度解析:商品详情获取与按图搜索商品(拍立淘)实战指南
python·1024程序员节
WangYan20222 小时前
ArcGIS Pro与Python下空间数据采集与管理——涵盖矢量、栅格、GPS、点云、多维数据与遥感云平台等
python·arcgis pro·空间数据采集与管理