首页 > 编程问答 >每日回报和 cumm 每日回报的累积每周、每月、每季度回报

每日回报和 cumm 每日回报的累积每周、每月、每季度回报

时间:2024-07-31 09:14:28浏览次数:8  
标签:python

我有一个包含日期、%每日回报、%CumRetn的数据框。

我需要一个Python代码来计算%每周回报,每周重置为零,并每年每周累积增加/减少 累积月度和季度回报也是如此

我知道如何进行重新采样(“W”或“M”或“Q”),但这不是我想要的。我正在使用 python 代码寻找一段时间 = 周/月/季度的 dagged-ramp 向上/向下

enter image description here


import pandas as pd

# 创建示例数据
df = pd.DataFrame({
    'Date': pd.to_datetime(['2023-01-02', '2023-01-03', '2023-01-04', '2023-01-05', '2023-01-06',
                           '2023-01-09', '2023-01-10', '2023-01-11', '2023-01-12', '2023-01-13',
                           '2023-01-16', '2023-01-17', '2023-01-18', '2023-01-19', '2023-01-20']),
    '% Daily Return': [0.01, 0.02, -0.01, 0.03, -0.02,
                       0.015, -0.01, 0.025, -0.005, 0.01,
                       0.014, -0.02, 0.03, -0.01, 0.02]
})

# 计算累积回报
df['% CumRetn'] = (1 + df['% Daily Return']).cumprod() - 1

# 计算每周回报
df['Weekly Return'] = df['% Daily Return'].groupby(pd.Grouper(key='Date', freq='W')).cumsum()

# 计算每周累积回报
df['Cumulative Weekly Return'] = (1 + df['Weekly Return']).groupby(pd.Grouper(key='Date', freq='W')).cumprod() - 1

# 计算每月回报
df['Monthly Return'] = df['% Daily Return'].groupby(pd.Grouper(key='Date', freq='M')).cumsum()

# 计算每月累积回报
df['Cumulative Monthly Return'] = (1 + df['Monthly Return']).groupby(pd.Grouper(key='Date', freq='M')).cumprod() - 1

# 计算每季度回报
df['Quarterly Return'] = df['% Daily Return'].groupby(pd.Grouper(key='Date', freq='Q')).cumsum()

# 计算每季度累积回报
df['Cumulative Quarterly Return'] = (1 + df['Quarterly Return']).groupby(pd.Grouper(key='Date', freq='Q')).cumprod() - 1

# 打印数据框
print(df)

这将创建一个包含每日回报、累积每日回报、每周回报、每周累积回报、每月回报、每月累积回报、每季度回报和每季度累积回报的列的 DataFrame。

解释:

  1. 按频率分组: 我们使用 pd.Grouper(key='Date', freq='W') 将数据按周、 pd.Grouper(key='Date', freq='M') 按月和 pd.Grouper(key='Date', freq='Q') 按季度分组。

  2. 使用 cumsum() 计算回报: 我们使用 cumsum() 函数计算每组中的累积回报。这将为该周/月/季度的每一天提供到目前为止的总回报。

  3. 使用 cumprod() 计算累积回报: 我们使用 cumprod() 函数计算每组中的累积回报。这将为该周/月/季度的每一天提供总的累积回报。

这应该可以为提供正在寻找的 dagged-ramp 向上/向下累积回报。

标签:python
From: 78814116

相关文章

  • 具有自引用的类装饰器的 Python 类型提示
    我的最终目标是编写一个系统来轻松记录函数调用(特别是类方法)。我首先编写一个带有包装方法的类Loggable,该方法允许我装饰子类方法并记录它们的调用|||现在我可以编写子类并记录它们的调用:Param=ParamSpec("Param")RetType=TypeVar("RetType")CountType=......
  • 如何在for循环中使用curve_fit函数在python中一次性创建多个回归?
    简而言之,我有两个矩阵,一个称为t,另一个称为y。每个都有7列。假设它们被称为a、b、c、d、e、f和g。我想要的是从a对a、b对b、...、g对g这两个矩阵进行回归。我已经设法使我的算法使用curve_fit对一列进行回归一次。但我真正希望的是它能够一次性完成7个回归......
  • 激活虚拟环境会让python消失?
    VisualStudioCode终端的屏幕截图如屏幕截图所示,python在Powershell中运行得很好。然后我在E:\DrewFTCAPI\ftcapivenv激活虚拟环境,然后python就消失了。不仅没有消失,它不运行任何东西,也不产生任何输出。我至少预计会出现某种类型的"python"i......
  • Python 3.6 中的相互递归类型,使用命名元组语法
    我正在尝试实现图的节点和边。这是我的代码:fromtypingimportNamedTuple,ListclassNode(NamedTuple):name:stredges:List[Edge]classEdge(NamedTuple):src:Nodedest:Node这会引发错误,因为创建Edge时未定义Node类型。......
  • 使用 keras 模型对函数进行 Python 类型提示
    如果我创建这样的函数:defmdl(input_shape):model=Sequential()model.add(Conv2D(depth=64,kernel_size=(3,3),input_shape=input_shape,activation='relu'))model.add(Dense(32),activation='relu')model.add(Dropout(0.3))m......
  • Python:自动完成可以用于列表中的元素吗?
    Python在函数参数和函数返回类型中具有类型提示。类的元素是否有类似的东西?我希望能够在如下示例中使用自动完成功能:classMyClass:defhello(self):print("Hello")mylist=[]mylist.append(MyClass())foriinmylist:i.hello()#Noautocomplete......
  • python 中 COM 对象的正确类型提示是什么?
    我在python中使用COM对象来向3rd方软件公开可编程接口。这是通过使用Dispatchfromwin32com.client来实现的。我的项目也一直在使用python.3.7中的类型提示,但是我不确定如何为了类型提示的目的定义这些COM对象的类型。这个问题涉及我拥有的所有COM......
  • 如何遍历Python字典同时避免KeyErrors?
    解析大型JSON时,某些键可能仅在某些情况下存在,例如出现错误时。从服务器的API获取200OK的情况并不少见,但是您得到的响应包含应检查的错误。处理此问题的最佳方法是什么?我知道使用类似||之类的东西。|是处理KeyError的一种方法。get()但是如果......
  • Python 中的递归数据类型
    Python中最接近Haskell中的递归数据类型的是什么?(即在定义自身时使用类型自己的定义。)编辑:为了给出递归类型的更具体定义,下面是Haskell中的二叉树:dataTreea=Leafa|Branch(Treea)(Treea)我的阅读方式如下:二叉树可以是叶子,也可以包含两......
  • 如何在Python中平滑相邻的多边形?
    我正在寻找一种平滑多边形的方法,以便相邻/接触的多边形保持接触。单个多边形可以轻松平滑,例如使用PAEK或Bezier插值(https://pro.arcgis.com/en/pro-app/latest/tool-reference/cartography/smooth-polygon.htm),这自然会改变它们的边界边缘。但是如何平滑所有多边形......