我的编程空间,编程开发者的网络收藏夹
学习永远不晚

pandas如何计算同比环比增长

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

pandas如何计算同比环比增长

计算同比环比增长

问题描述

我有2017.1-2018.12的销售数据,计算每一个月的 同比和环比增长,没有的话 用null代替

注释:

  • 同比 和 环比 都是为了显示数据的变化速度,但是基数不同,同比侧重长期数据趋势变化,环比侧重于短期内数据趋势变化
  • 同比是指在同一时期内的数据趋势变化,用于本期与同期的对比,例如本期2018-02月销售额与同期2017-02月销售额做对比。【(本期 - 同期)/ 同期】
  • 环比是指在短时间内的数据趋势变化,用去本期与临近一起的对比,例如本期2018-02月销售额与上一期2018-01月销售额做对比。【(本期 - 临近一期)/ 临近一期】

数据准备

import pandas as pd
import random
rng = list(pd.date_range('1/1/2017', periods=24, freq='M')) #生成日期
mony = [random.randint(1000,9000) for i in range(0,24)] #随机生成销售额
data = pd.DataFrame({'rng':rng,'mony':mony}) #组成一个dataframe

计算环比增长

方法一:

for i in range(0,len(data)):
    if i == 0:
        data['huanbi'][i] = 'null'
    else:
        data['huanbi'][i] = format((data['mony'][i] - data['mony'][i-1])/data['mony'][i-1],'.2%')
        #format(res,'.2%') 小数格式化为百分数

方法二:

使用diff(periods=1, axis=0)) 一阶差分函数

  • periods:移动的幅度 默认值为1
  • axis:移动的方向,{0 or ‘index’, 1 or ‘columns’},如果为0或者’index’,则上下移动,如果为1或者’columns’,则左右移动。默认列向移动
data['huanbi_1'] = data.mony.diff()

方法三:

使用pct_change()

data['huanbi_1'] = data.mony.pct_change()
data.fillna(0,inplace=True)

计算同比增长

使用一阶差分函数diff()

data['tongbi_shu'] = data.mony.diff(12)
data.fillna(0,inplace=True)
data['tongbi'] = data['tongbi_shu']/(data['mony'] - data['tongbi_shu'])
``

同比和环比计算公式

  • 同比增长率=(本期数-同期数)÷同期数×100%
  • 环比增长率=(本期数-上期数)/上期数×100%。

简单地说,就是同比、环比与定基比,都可以用百分数或倍数表示。

定基比发展速度,也简称总速度,一般是指报告期水平与某一固定时期水平之比,表明这种现象在较长时期内总的发展速度。

  • 同比发展速度,一般指是指本期发展水平与上年同期发展水平对比,而达到的相对发展速度。
  • 环比发展速度,一般是指报告期水平与前一时期水平之比,表明现象逐期的发展速度。同比和环比,这两者所反映的虽然都是变化速度,但由于采用基期的不同,其反映的内涵是完全不同的;

一般来说,环比可以与环比相比较,而不能拿同比与环比相比较;而对于同一个地方,考虑时间纵向上发展趋势的反映,则往往要把同比与环比放在一起进行对照。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

pandas如何计算同比环比增长

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL中如何计算同比和环比

目录前言我们先来看看什么是同比,什么是环比:那同比增长率和环比增长率又如何计算呢:同比和环比的区别在mysql中如何计算同比和环比数据准备计算同比和环比sql解析总结前言今天在做数据建模的时候,ads层的需求中有个叫同比和http://w
2022-06-22

Python中怎么计算环比增长率

Python中怎么计算环比增长率,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。 认识环比增长率很多企业比较注重自己的业务增长情况,时常会需要计算同比增长率和环比
2023-06-16

java怎么计算同比增长工具类

本篇内容主要讲解“java怎么计算同比增长工具类”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“java怎么计算同比增长工具类”吧!java 计算同比增长工具类为了数据的严谨性,统一装换为BigD
2023-06-20

MySQL中怎么计算同比和环比

这篇文章主要介绍“MySQL中怎么计算同比和环比”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“MySQL中怎么计算同比和环比”文章能帮助大家解决问题。我们先来看看什么是同比,什么是环比:同比:通常是
2023-07-02

Python pandas如何计算每行的增长率与累计增长率

小编给大家分享一下Python pandas如何计算每行的增长率与累计增长率,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!读取数据:FacebookDf=pd.read_excel(rD:\jupyter\Untitled
2023-06-29

sql如何计算百分比

有三种主要方法可以利用 sql 计算百分比:直接计算、使用窗口函数以及使用 case 表达式。直接计算通过将分子除以分母并乘以 100 获得百分比;窗口函数允许根据组按分母值计算百分比;而 case 表达式则可依据条件计算不同的百分比。如何
sql如何计算百分比
2024-06-06

中文文本长度计算的异同:lenb函数和len函数的比较

lenb函数和len函数对于中文文本长度计算的异同点,需要具体代码示例【引言】在使用编程语言处理中文文本时,我们经常要计算文本的长度。在Python中,常用的计算文本长度的函数有len和lenb。这两个函数在处理中文文本时有一些异同点,本
中文文本长度计算的异同:lenb函数和len函数的比较
2024-01-29

Python如何实现杰卡德距离以及环比算法

这篇文章将为大家详细讲解有关Python如何实现杰卡德距离以及环比算法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。前言NLP-字符串相似性计算、集合相似性度量杰卡德距离是什么?杰卡德距离(Jaccard
2023-06-29

PHP如何使用键名比较计算数组的差集

使用键名比较计算数组差集,即找出第一个数组中存在但不在第二个数组中的元素。PHP中提供了array_diff_key()函数,可根据键名比较两个数组,返回差集。另外,也可以手动比较键名计算差集。array_diff_key()通常更快,但对于小数组,手动比较的性能差异可以忽略不计。
PHP如何使用键名比较计算数组的差集
2024-04-02

Java如何使用键名比较计算数组的差集

Java中利用键名比较计算数组差集的方法:创建两个HashMap,存储数组元素及其出现次数。遍历数组并插入HashMap,若元素已存在则计数增加。比较HashMap,将第二个HashMap中不存在于第一个HashMap中的键名添加到差集中。获取差集,即第二个HashMap中不包含于第一个HashMap中的键名集合。
Java如何使用键名比较计算数组的差集
2024-04-02

PHP如何使用键名比较计算数组的交集

本文介绍了一种使用键名比较来计算PHP数组交集的方法。此方法高效、准确,但仅适用于具有唯一键名的数组。它不考虑元素值,因此对于需要比较元素值的情况,可能需要其他方法。替代方法包括使用多维数组、集合操作或散列表。
PHP如何使用键名比较计算数组的交集
2024-04-02

Java如何使用键名比较计算数组的交集

本篇教程介绍了如何使用键名比较来计算数组交集。该算法通过将数组转换为Map,然后遍历其中一个Map的键名,检查是否存在于另一个Map中,从而实现元素的唯一性。实现简单易懂,代码示例和详细介绍有助于理解。
Java如何使用键名比较计算数组的交集
2024-04-02

阿里云服务器佣金比例是多少?如何计算?

阿里云服务器作为国内领先的云服务商,其佣金比例是多少?这个问题一直受到广大商家的关注。本文将详细介绍阿里云服务器佣金比例的计算方法,并解答如何获取阿里云服务器的佣金比例。正文:阿里云服务器是中国领先的云计算服务提供商,提供包括计算、存储、网络、安全、数据库、大数据、人工智能等各种云计算服务。作为商家,如何获取阿里
阿里云服务器佣金比例是多少?如何计算?
2023-11-08

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录