pandas.DataFrame.pct_change#

DataFrame.pct_change(periods=1, fill_method=None, freq=None, **kwargs)[源代码]#

当前元素与先前元素之间的分数变化。

默认情况下,计算与前一行的分数变化。这对于比较时间序列元素中的变化分数非常有用。

备注

尽管这个方法的名字如此,它计算的是分数变化(也称为每单位变化或相对变化),而不是百分比变化。如果你需要百分比变化,请将这些值乘以100。

参数:
periodsint, 默认 1

用于形成百分比变化的周期。

fill_methodNone

必须是 None。此参数将在 pandas 的未来版本中移除。

自 2.1 版本弃用: 除了 fill_method=None 之外,fill_method 的所有选项都已弃用。

freqDateOffset, timedelta 或 str, 可选

从时间序列API使用的增量(例如 ‘ME’ 或 BDay())。

**kwargs

额外的关键字参数被传递到 DataFrame.shiftSeries.shift 中。

返回:
系列或数据框

与调用对象相同的类型。

参见

Series.diff

计算 Series 中两个元素的差值。

DataFrame.diff

计算 DataFrame 中两个元素的差值。

Series.shift

将索引移动若干个周期。

DataFrame.shift

将索引移动若干个周期。

示例

系列

>>> s = pd.Series([90, 91, 85])
>>> s
0    90
1    91
2    85
dtype: int64
>>> s.pct_change()
0         NaN
1    0.011111
2   -0.065934
dtype: float64
>>> s.pct_change(periods=2)
0         NaN
1         NaN
2   -0.055556
dtype: float64

查看一个系列中百分比变化,其中用最后一个有效观察值填充NA直到下一个有效观察值。

>>> s = pd.Series([90, 91, None, 85])
>>> s
0    90.0
1    91.0
2     NaN
3    85.0
dtype: float64
>>> s.ffill().pct_change()
0         NaN
1    0.011111
2    0.000000
3   -0.065934
dtype: float64

DataFrame

1980年1月1日至1980年3月1日期间法郎、德国马克和意大利里拉的变化百分比。

>>> df = pd.DataFrame(
...     {
...         "FR": [4.0405, 4.0963, 4.3149],
...         "GR": [1.7246, 1.7482, 1.8519],
...         "IT": [804.74, 810.01, 860.13],
...     },
...     index=["1980-01-01", "1980-02-01", "1980-03-01"],
... )
>>> df
                FR      GR      IT
1980-01-01  4.0405  1.7246  804.74
1980-02-01  4.0963  1.7482  810.01
1980-03-01  4.3149  1.8519  860.13
>>> df.pct_change()
                  FR        GR        IT
1980-01-01       NaN       NaN       NaN
1980-02-01  0.013810  0.013684  0.006549
1980-03-01  0.053365  0.059318  0.061876

GOOG 和 APPL 股票交易量的变化百分比。显示计算列之间的百分比变化。

>>> df = pd.DataFrame(
...     {
...         "2016": [1769950, 30586265],
...         "2015": [1500923, 40912316],
...         "2014": [1371819, 41403351],
...     },
...     index=["GOOG", "APPL"],
... )
>>> df
          2016      2015      2014
GOOG   1769950   1500923   1371819
APPL  30586265  40912316  41403351
>>> df.pct_change(axis="columns", periods=-1)
          2016      2015  2014
GOOG  0.179241  0.094112   NaN
APPL -0.252395 -0.011860   NaN