Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/python/345.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 对系列的累积值应用函数_Python_Pandas - Fatal编程技术网

Python 对系列的累积值应用函数

Python 对系列的累积值应用函数,python,pandas,Python,Pandas,熊猫中是否存在将函数应用于序列的累积值而不是滚动值的rolling\u apply?我知道存在cumsum、cumprod、cummax和cummin,但我想应用一个自定义函数。您可以使用。下面是一个简单的例子,它只做累计和,但您可以编写任何您想要的函数 import pandas as pd df = pd.DataFrame({'data':[10*i for i in range(0,10)]}) def sum_(x): return sum(x) df['example

熊猫中是否存在将函数应用于序列的累积值而不是滚动值的
rolling\u apply
?我知道存在
cumsum
cumprod
cummax
cummin
,但我想应用一个自定义函数。

您可以使用。下面是一个简单的例子,它只做累计和,但您可以编写任何您想要的函数

import pandas as pd

df = pd.DataFrame({'data':[10*i for i in range(0,10)]})

def sum_(x):
    return sum(x)


df['example'] = pd.expanding_apply(df['data'], sum_)

print(df)

#   data  example
#0     0        0
#1    10       10
#2    20       30
#3    30       60
#4    40      100
#5    50      150
#6    60      210
#7    70      280
#8    80      360
#9    90      450

[对@Ffisegydd答复的后续行动]

熊猫的更新==1.0.5

df['example'] = df['data'].expanding().apply(sum_)

在new pandas>=0.18.0中,它被DataFrame.Expansing().apply()替换