计算基金最大回撤的Python代码

1 篇文章 0 订阅
1 篇文章 0 订阅

计算基金最大回撤的Python代码

def get_maximum_retracement(date_totalworth_dict:dict):
    """
    date_totalworth_dict:dict
    eg.  -->{'2019-10-16': 1.0022, '2019-09-11': 1.0, '2019-09-12': 1.0, }
    return maximum_retracement
    """
    sort_dates = sorted(date_totalworth_dict.keys())
    retracement_list = []
    for index1, date1 in enumerate(sort_dates):
        for index2, date2 in enumerate(sort_dates[:index1]):
            result = 1 - date_totalworth_dict[date1] / date_totalworth_dict[date2]
            if result > 0:
                retracement_list.append(result)
    return max(retracement_list)
Python计算股票最大回撤的方法可以通过使用rolling函数来实现。首先,需要计算选取周期内的最大净值,即窗口滚动值里的最大值。这可以通过使用rolling函数后加.max()来实现。具体代码如下: ```python data['roll_max'] = pd.DataFrame(data)['close'].rolling(window=window, min_periods=1).max() ``` 接下来,计算当天的回撤比,即当天股价与股价峰值之间的比例。具体公式为(当天股价 - 股价峰值)/股价峰值,可以通过下面的代码实现: ```python data['daily_dd'] = data['close'] / data['roll_max'] - 1 ``` 最后,计算选取周期内的最大回撤比,取最小值作为最大回撤。这里将回撤比当成负数处理。具体代码如下: ```python data['max_dd'] = data['daily_dd'].rolling(window=window, min_periods=1).min() ``` 这样就可以得到带最大回撤值的新数据。以上是计算股票最大回撤Python代码实现。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [股票python量化交易016-计算最大回撤](https://blog.csdn.net/Johnny2004/article/details/124918005)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值