首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在data.table中查找按2个因子分组的两个变量的变化

在data.table中查找按2个因子分组的两个变量的变化
EN

Stack Overflow用户
提问于 2021-02-09 00:32:32
回答 1查看 22关注 0票数 0

我有一些不定期访问的地块,用来记录几个物种的生物量。我想记录每个物种生物量的变化,以及在间隔开始时间隔的持续时间

样本数据如下

代码语言:javascript
复制
plot <- c(rep(1,4), rep(2,3))
species <- c(rep(c('a','b'), 2), rep('a',3))
year <- c(1,1,3,3,2,5,13)
biom <- c(5,2,8,4,3,9,18)

DT <- data.table(plot=plot, sp=sp,year=year,biom=biom)

所需的输出将如下所示

代码语言:javascript
复制
elapsed = c(2,2,NA,NA,3,8,NA)
dbiom = c(3,2,NA,NA,6,9,NA)

(例如,第1号地块中物种a的生物量变化,第1年的第一次调查到第2年的第二次调查为+3,耗时为2年)

我一直在使用data.table中的'shift‘运算符,但我无法让它工作

代码语言:javascript
复制
setkey(DT, plot, sp , year)
cols = c("year","biom")
anscols = paste("lead", cols, sep="_")

b4 <- b3[ , (anscols) := shift(.SD, 1, NA, type = "lead"), 
     .SDcols=cols, by = c(plot, sp)]

我一直收到“Error in eval(bysub,x,parent.frame()):找不到对象”%1“”

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-02-09 01:01:32

像这样的东西能奏效吗?

代码语言:javascript
复制
library(data.table)

plot <- c(rep(1,4), rep(2,3))
sp <- c(rep(c('a','b'), 2), rep('a',3))
year <- c(1,1,3,3,2,5,13)
biom <- c(5,2,8,4,3,9,18)

DT <- data.table(plot=plot, sp=sp,year=year,biom=biom)

elapsed = c(2,2,NA,NA,3,8,NA)
dbiom = c(3,2,NA,NA,6,9,NA)

DT[
  order(plot, year),
  .(year, biom,
    elapsed = year - shift(year),
    dbiom = biom - shift(biom)
  ),
  by = c("sp", "plot")
  ]
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66105555

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档