虽然我发现了几个类似的问题,但我无法在基础 R 中找到解决我的问题的简单方法。
我想计算一组数据(此处为 y 值)的同比百分比变化,并将此“Delta”系列作为新列添加到我的数据框中。
例如:
>x = c(2000,2001,2002,2003,2004,2005,2006)
>y = c(100,104,106,108,112,115,121)
>df = data.frame(x,y)
如果我通过读取 .csv 文件加载数据该怎么办?我是否必须将此数据转换为数据框?
数据表_1.9.5 https://github.com/Rdatatable/data.table推出新功能shift
,默认情况下将是type='lag'
and n=1L
。如果需要更改,您可以指定这些参数。setDT
皈依者data.frame
to data.table
,创建一个新列(:=
)基于标准(y/shift(y)...
)
library(data.table)
setDT(df)[, new.col := y/shift(y) - 1]
或者在 R 基数中(来自 @David Arenburg 的评论)
transform(df, new.col=c(NA,y[-1]/y[-nrow(df)]-1))
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)