作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我一直在尝试计算从第一季度到下一年第一季度的增长率。
在 excel 中,公式看起来像这样 ((B6-B2)/B2)*100。
在 R 中完成此任务的最佳方法是什么?我知道如何获得不同时期的差异,但无法以 4 个时期的差异来完成。
这是代码:
date <- c("2000-01-01","2000-04-01", "2000-07-01",
"2000-10-01","2001-01-01","2001-04-01",
"2001-07-01","2001-10-01","2002-01-01",
"2002-04-01","2002-07-01","2002-10-01")
value <- c(1592,1825,1769,1909,2022,2287,2169,2366,2001,2087,2099,2258)
df <- data.frame(date,value)
date value
1 2000-01-01 1592
2 2000-04-01 1825
3 2000-07-01 1769
4 2000-10-01 1909
5 2001-01-01 2022
6 2001-04-01 2287
7 2001-07-01 2169
8 2001-10-01 2366
9 2002-01-01 2001
10 2002-04-01 2087
11 2002-07-01 2099
12 2002-10-01 2258
最佳答案
这是使用 dplyr
的选项包裹:
# Convert date column to date format
df$date = as.POSIXct(df$date)
library(dplyr)
library(lubridate)
arrange
函数只是确保每个季度的数据按日期排序。然后我们添加
yearOverYear
列使用
mutate
它计算每个季度的当前年度与上一年的比率。
df = df %>% group_by(month=month(date)) %>%
arrange(date) %>%
mutate(yearOverYear=value/lag(value,1))
date value month yearOverYear
1 2000-01-01 1592 1 NA
2 2001-01-01 2022 1 1.2701005
3 2002-01-01 2001 1 0.9896142
4 2000-04-01 1825 4 NA
5 2001-04-01 2287 4 1.2531507
6 2002-04-01 2087 4 0.9125492
7 2000-07-01 1769 7 NA
8 2001-07-01 2169 7 1.2261164
9 2002-07-01 2099 7 0.9677271
10 2000-10-01 1909 10 NA
11 2001-10-01 2366 10 1.2393924
12 2002-10-01 2258 10 0.9543533
df = df %>% group_by(month=month(date)) %>%
arrange(date) %>%
mutate(yearOverYear=value/lag(value,1)) %>%
ungroup() %>% arrange(date)
data.table
library(data.table) # v1.9.5+
setDT(df)[, .(date, yoy = (value-shift(value))/shift(value)*100),
by = month(date)
][order(date)]
关于r - 季度同比增长率,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30678606/
我试图了解我的推理是否正确: 如果我得到以下代码片段并要求我找出它是 Big O: for(int i = 3; i < 1000; i++) sum++; 我想说 O(n),因为我们正在处
我有一个几个月前的 git 仓库。是否可以计算/绘制内部 git 存储库(压缩大小)的大小(以 MB 为单位)作为推送到远程的提交(或与此相关的日期)的函数? 由于可以并行开发分支,因此给定的提交可能
我是一名优秀的程序员,十分优秀!