pandas窗口函数

.rolling()函数

rolling函数固定窗口大小,滚动计算,每次滚动1格
先随机创建一个数据集,有4列,10行

df = pd.DataFrame(np.random.randn(10, 4),index = pd.date_range('1/1/2020', periods=10),columns = ['A', 'B', 'C', 'D'])

在这里插入图片描述

#计算3天的平均值,第三个元素的值将是n,n-1和n-2元素的平均值。
df.rolling(window=3).mean()
在这里插入图片描述

方法签名

DataFrame.rolling(window, min_periods=None, center=False, win_type=None,
on=None, axis=0, closed=None)

window:表示时间窗的大小,有两种形式:1)使用数值int,则表示观测值的数量,即向前几个数据;2)也可以使用offset类型,这种类型较复杂,使用场景较少,此处暂不做介绍;
min_periods:每个窗口最少包含的观测值数量,小于这个值的窗口结果为NA。值可以是int,默认None。offset情况下,默认为1;
center: 把窗口的标签设置为居中,布尔型,默认False,居右
win_type: 窗口的类型。截取窗的各种函数。字符串类型,默认为None;
on: 可选参数。对于dataframe而言,指定要计算滚动窗口的列。值为列名。
axis: 默认为0,即对列进行计算
closed:定义区间的开闭,支持int类型的window。对于offset类型默认是左开右闭的即默认为right。可以根据情况指定为left、both等。

常用函数:
rolling()函数除了mean(),还支持很多函数,比如:
count() 非空观测值数量
sum() 值的总和
median() 值的算术中值
min() 最小值
max() 最大
std() 贝塞尔修正样本标准差
var() 无偏方差
skew() 样品偏斜度(三阶矩)
kurt() 样品峰度(四阶矩)
quantile() 样本分位数(百分位上的值)
cov() 无偏协方差(二元)
corr() 相关(二进制)
借助 agg ()函数可以快速实现多个聚类函数,并输出结果,同时还可以进行重命名;

expanding

参数与rolling函数相同,expanding()函数只设置最小的观测值数量,不固定窗口大小,实现累计计算,即不断扩展

df.expanding(min_periods=3).mean()

在这里插入图片描述

pandas提供了多种聚合函数来对数据进行统计分析。其中一种常用的聚合函数是`agg()`函数,该函数可以对分组对象使用不同的统计方法。使用`Groupby.agg(func)`的语法格式,可以针对不同的变量使用不同的统计方法进行聚合操作。 另外,pandas还提供了移动窗口函数`rolling()`,它可以与mean、count、sum、median、std等聚合函数一起使用,用于对数据进行滑动窗口的统计计算。`rolling()`函数的语法格式为`rolling(window=n, min_periods=None, center=False)`。通过指定窗口大小、是否允许窗口中的缺失值、窗口位置是否在窗口中心等参数,可以对数据进行滑动窗口的聚合操作。 此外,还有指数加权移动函数`ewm()`,全称为Exponentially Weighted Moving。该函数先对序列元素进行指数加权运算,然后计算加权后的均值。可以通过指定com、span或halflife参数来实现不同的指数加权移动计算方式。示例如下: ```python import pandas as pd import numpy as np df = pd.DataFrame(np.random.randn(10, 4), index=pd.date_range('12/1/2020', periods=10), columns=['A', 'B', 'C', 'D']) # 设置com=0.5,先加权再求均值 print(df.ewm(com=0.5).mean()) ``` 在上述示例中,使用了`ewm()`函数对DataFrame的每一列进行指数加权移动计算,通过设置`com=0.5`来指定加权的程度。 综上所述,pandas提供了多种聚合函数,包括`agg()`、`rolling()`和`ewm()`等,可以根据需求选择合适的函数来进行数据统计和分析。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值