栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

asfreq和resample之间的区别

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

asfreq和resample之间的区别

让我用一个例子来说明:

# generate a series of 365 days# index = 20190101, 20190102, ... 20191231# values = [0,1,...364]ts = pd.Series(range(365), index = pd.date_range(start='20190101',     end='20191231',    freq = 'D'))ts.head()output:2019-01-01    02019-01-02    12019-01-03    22019-01-04    32019-01-05    4Freq: D, dtype: int64

现在,按季度重新采样数据:

ts.asfreq(freq='Q')output:2019-03-31     892019-06-30    1802019-09-30    2722019-12-31    364Freq: Q-DEC, dtype: int64

asfreq()
返回一个
Series
与每个季度在它的最后一天对象。

ts.resample('Q')output:DatetimeIndexResampler [freq=<QuarterEnd: startingMonth=12>, axis=0, closed=right, label=right, convention=start, base=0]

重新采样返回a

DatetimeIndexResampler
,您将看不到实际内容。将其视为
groupby
方法。它创建一个
bins
(组)列表:

bins = ts.resample('Q')bin.groupsoutput: {Timestamp('2019-03-31 00:00:00', freq='Q-DEC'): 90, Timestamp('2019-06-30 00:00:00', freq='Q-DEC'): 181, Timestamp('2019-09-30 00:00:00', freq='Q-DEC'): 273, Timestamp('2019-12-31 00:00:00', freq='Q-DEC'): 365}

到目前为止,除了返回类型外,没有什么不同。让我们计算每个季度的平均值:

# (89+180+272+364)/4 = 226.25ts.asfreq(freq='Q').mean()output:226.25

mean()
施加时,它输出平均的所有值。请注意,这不是每个季度的平均值,而是每个季度最后一天的平均值。

要计算每个季度的平均值:

ts.resample('Q').mean()output:2019-03-31     44.52019-06-30    135.02019-09-30    226.52019-12-31    318.5

您可以执行功能更强的操作

resample()
asfreq()

想想

resample
groupby
+每一个方法,你可以调用后
groupby
(例如,平均值,总和,应用,你的名字)。

可以将其

asfreq
视为
fillna()
功能有限的过滤器机制(在fillna()中,您可以指定
limit
,但asfreq()不支持它)。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/571151.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号