教你利用 Python 计算同比、环比、定基比
1. 问题描述
日常处理销售相关的数据时,经常会遇到需要计算 同比、环比、定基比
的问题,计算方法是 「(当期 / 比较期 -1) * 100%」,在 Excel 中使用公式引用进行计算非常方便,其实使用 python 来做相应的计算也是非常简单的,本文就使用 python 来进行操作,计算出想要的结果。
先读取数据集,是 2019 年 1 月至 2021 年 3 月的销售数据。
import pandas as pd
import numpy as np
import time
import datetime
df_raw = pd.read_excel('./data.xlsx',sheet_name='Sheet1')
df_raw['日期'] = pd.to_datetime(df_raw['日期'])
df_raw = df_raw.set_index('日期')
df_raw
![](https://filescdn.proginn.com/5cc38139a99b7e082391e37b38ddf58c/fa8ef252bf143c2797ff275cf7364f85.webp)
2. 解决方法
2.1 计算同比和环比
使用 pct_change() 函数,直接可以计算百分比对比(同比、环比)
df_raw['环比'] = df_raw['销售额'].pct_change(periods=1)
df_raw['同比'] = df_raw['销售额'].pct_change(periods=12)
df_raw['环比'] = df_raw['环比'].apply(lambda x:str(round(x * 100,2)) + '%').str.replace('nan%','')
df_raw['同比'] = df_raw['同比'].apply(lambda x:str(round(x * 100,2)) + '%').str.replace('nan%','')
df_raw
![](https://filescdn.proginn.com/86c90fc73e4a045ae9a6a1d1324b70bb/8b3e060ac470964be2d46ad324fd7ada.webp)
2.2 定基比
计算定基比(以 '2020-10-01' 为基准)
fixed_str = '2020-10-01'
# fixed_row = datetime.datetime.strptime(fixed_str, '%Y-%m-%d').date()
fixed_num = df_raw.loc[fixed_str,'销售额']
df_raw['定基比'] = df_raw['销售额'] / fixed_num - 1
df_raw['定基比'] = df_raw['定基比'].apply(lambda x:str(round(x * 100,2)) + '%').str.replace('nan%','')
df_raw
![](https://filescdn.proginn.com/9acee580602a1a7293928e7683b0b2f3/ffbafbfa3302d621fa596d6859e7f550.webp)
3. 总结
使用 pandas 库
中的pct_change() 函数
配合periods 参数
可以方便地计算同比和环比。使用 apply
自定义函数计算出定基比。
4. 资料下载
我已将以上配套数据文件和代码文件打包上传至我的 Github 和 Gitee,感兴趣的读者可以下载学习和练手。
「Github 项目地址」
「https://github.com/don2vito/wechat_project/tree/master/同比、环比、定基比」
「Gitee 项目地址」
「https://gitee.com/don2vito/wechat_official_account/blob/master/023_《和时间做朋友》系列 /03. 同比、环比、定基比.ipynb」
欢迎关注
![音符](https://filescdn.proginn.com/4b9199c1a900753d87c9a456fe82c727/623c6ce2a0788e6bffcf146b38ea46ae.webp)
![](https://filescdn.proginn.com/5aeebc81405c8187838f08dea2c7f583/a00c00b249466d76cf8a6f82dc906f2f.webp)
![](https://filescdn.proginn.com/bd0be63a92f77c16556da177f518cf83/f0366bf968300458f90fb5dc79cb7303.webp)
![](https://filescdn.proginn.com/20940b15a14eb02c74aebca45f555ceb/c4280402b175169245a9e31655226c4c.webp)
![](https://filescdn.proginn.com/574a378912da4470aea2cfd910386e96/601657d337567ba8583c4e72a0d0f9dd.webp)
评论