【Quant102】 经典技术指标 Pandas 实现(第一部分)(3)

简介: 【Quant102】 经典技术指标 Pandas 实现(第一部分)

【Quant102】 经典技术指标 Pandas 实现(第一部分)(2)https://developer.aliyun.com/article/1524457

RSI 策略

假设你是个高级程序员和量化研究员,编写函数实现RSI策略。函数接受数据帧df,RSI列名称rsi_colinplace参数控制是否原地更新df。买卖信号应保存在signal列中。最后返回df

def rsi_strategy(df, rsi_col='rsi', inplace=False):
    """
    实现RSI策略,生成买卖信号。
    
    参数:
    df : DataFrame
        包含RSI指标数据的DataFrame,必须包含'rsi_col'列。
    rsi_col : str
        RSI指标的列名。
    inplace : bool, optional
        是否在原地更新DataFrame,默认为False。
    
    返回:
    df : DataFrame
        原始DataFrame,增加了一个名为'signal'的列,包含买卖信号。
    """
    
    # 复制DataFrame以避免修改原始数据
    if not inplace:
        df = df.copy()
    
    # 初始化信号列,默认为无操作
    df['signal'] = 0
    
    # 产生买入信号:RSI低于30
    df.loc[df[rsi_col] < 30, 'signal'] = 1
    
    # 产生卖出信号:RSI高于70
    df.loc[df[rsi_col] > 70, 'signal'] = -1
    
    return df

KDJ 指标

假设你是个高级程序员和量化研究员,编写函数实现 KDJ 指标。函数接受数据帧dfinplace参数控制是否原地更新dfdf包含四个列:open开盘价、high最高价、low最低价和close收盘价。所有指标都应当保存到df中,最后返回df

def kdj(df, k_col='K', d_col='D', j_col='J', n=9, m1=3, m2=3, inplace=False):
    """
    计算KDJ指标,并更新DataFrame。
    
    参数:
    df : DataFrame
        包含价格数据的DataFrame,必须包含'open', 'high', 'low', 'close'列。
    n : int, optional
        计算KDJ指标的时间窗口,默认为9。
    m1 : int, optional
        计算D线的时间窗口,默认为3。
    m2 : int, optional
        计算J线的参数,默认为3。
    inplace : bool, optional
        是否在原地更新DataFrame,默认为False。
    
    返回:
    df : DataFrame
        包含KDJ指标的新DataFrame(如果inplace为False)。
    """
    
    # 复制DataFrame以避免修改原始数据
    if not inplace:
        df = df.copy()
    
    # 计算最小值和最大值
    low_min = df['low'].rolling(window=n).min()
    high_max = df['high'].rolling(window=n).max()
    
    # 计算K值
    df[k_col] = (df['close'] - low_min) / (high_max - low_min) * 100
    
    # 计算D值
    df[d_col] = df[k_col].rolling(window=m1).mean()
    
    # 计算J值
    df[j_col] = m2 * df[d_col] - df[k_col].rolling(window=m2).mean()
    
    return df

【Quant102】 经典技术指标 Pandas 实现(第一部分)(4)https://developer.aliyun.com/article/1524459

相关文章
|
新零售 机器学习/深度学习 人工智能
云栖新闻|助力企业智能化升级 达摩院“新一代企业智能服务论坛”圆满举行
介绍阿里云智能客服最新进展,包括全渠道全场景覆盖的云上产品矩阵,从智能服务向智能营销场景延申的解决方案,国内首创的智能策略中心的发布,号召客户和生态伙伴与我们圆桌探讨智能服务行业未来。
云栖新闻|助力企业智能化升级 达摩院“新一代企业智能服务论坛”圆满举行
|
5月前
|
存储 缓存 Java
Python中的__slots__:减少内存占用的高级技巧
本文深入解析Python的`__slots__`机制,从内存开销原理、优化机制、实践技巧、继承处理到典型场景(如金融系统、游戏实体、缓存),全面阐述其减少30%–50%内存占用、提升20%–50%属性访问速度的核心价值,并提醒使用限制与最佳实践。(239字)
253 0
|
6月前
|
监控 网络协议 Ubuntu
Debian网络延迟排查指南(从零开始诊断网络卡顿问题)
本文介绍如何在Debian系统中诊断网络延迟问题,涵盖ping、traceroute、mtr等工具的使用方法,帮助用户定位延迟根源,优化网络性能。适合Linux新手快速掌握网络诊断技巧。
|
10月前
|
安全 测试技术 API
Python 单元测试详解
单元测试是Python开发中不可或缺的环节,能确保代码按预期运行、发现Bug、提升代码质量并支持安全重构。本文从基础概念讲起,逐步介绍Python单元测试的实践方法,涵盖unittest框架、pytest框架、断言使用、Mock技巧及测试覆盖率分析,助你全面掌握单元测试技能。
547 0
|
程序员 Python
【Quant102】 经典技术指标 Pandas 实现(第一部分)(4)
【Quant102】 经典技术指标 Pandas 实现(第一部分)
264 0
|
索引 Python
Pandas学习笔记之Dataframe
Pandas学习笔记之Dataframe
2500 2
|
Unix 数据挖掘
一文读懂Polars中的时间处理:从字符串到时间戳的转换秘籍!
一文读懂Polars中的时间处理:从字符串到时间戳的转换秘籍!
1162 0
|
程序员 Python
【Quant102】 经典技术指标 Pandas 实现(第一部分)(2)
【Quant102】 经典技术指标 Pandas 实现(第一部分)
297 0
|
测试技术 开发工具 git
推荐一个不错的弱网模拟框架
在《APP网络性能测试白皮书》中我们已经探讨了为什么要做弱网测试以及弱网测试中需要关注的一些指标,在《弱网环境搭建方案选型》这篇文章中我们讨论了各种弱网模拟方案的优缺点,其中在预算有限的情况下我是比较推荐基于ATC和树莓派去搭建弱网模拟平台的,这块的内容可以参考《树莓派搭建弱网测试环境全纪录(1)》和《树莓派搭建弱网测试环境全纪录(2)》,基于ATC的方案其实已经可以满足绝大部分场景的需求,但是原生的ATC方案易用性比较差,每次修改网络场景需要把被测APP置于后台,切换到网络模拟界面改参数,然后再切回被测APP,影响被测APP的操作连贯性,今天我要推荐的是一个基于ATC改造后的弱网模拟工具
800 0
推荐一个不错的弱网模拟框架
|
Python
python股票量化交易(8)---K线图:锤头,射击之星,早晨之星
python股票量化交易(8)---K线图:锤头,射击之星,早晨之星
1812 0
python股票量化交易(8)---K线图:锤头,射击之星,早晨之星

热门文章

最新文章