如何从熊猫数据框制作标准化系列?

Posted

技术标签:

【中文标题】如何从熊猫数据框制作标准化系列?【英文标题】:How to make a normalizated series from pandas dataframe? 【发布时间】:2021-07-20 09:11:28 【问题描述】:

我有以下代码:

df = pd.DataFrame(
    'FR': [4.0405, 4.0963, 4.3149, 4.500],
    'GR': [1.7246, 1.7482, 1.8519, 4.100],
    'IT': [804.74, 810.01, 860.13, 872.01],
    index=['1980-04-01', '1980-03-01', '1980-02-01', '1980-01-01'])

df = df.iloc[::-1]

df2 = df.pct_change()

df2 = df2.iloc[::-1]
df = df.iloc[::-1]

last=100
serie = []
serie.append(last)

for i in list(df.index.values[::-1][1:]):
    last = last*(1+df2['FR'][i])
    serie.append(last)                    
serie

我得到了我的预期:

[100, 95.88666666666667, 91.02888888888891, 89.7888888888889]

但我正在寻找一种更简单的方法来做到这一点。

谢谢

【问题讨论】:

【参考方案1】:

试试cumprod:

df.iloc[::-1].pct_change().add(1).fillna(1).cumprod()

输出:

                  FR        GR        IT
1980-01-01  1.000000  1.000000  1.000000
1980-02-01  0.958867  0.451683  0.986376
1980-03-01  0.910289  0.426390  0.928900
1980-04-01  0.897889  0.420634  0.922856

【讨论】:

以上是关于如何从熊猫数据框制作标准化系列?的主要内容,如果未能解决你的问题,请参考以下文章

如何从数据框熊猫中制作列表列表?

如何使用一系列列名从熊猫数据框中获取系列?

如何从一系列数组构造熊猫数据框

基于列标准的熊猫数据框重采样

熊猫数据框:在固定其他列的列中提取具有特定标准/条件最小值的数据[重复]

我如何在python中使用for循环制作熊猫数据框对象