作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这个问题在这里已经有了答案:
R Add previous month value as a column
(2 个回答)
6年前关闭。
我有一个包含交易的数据表。除其他事项外,交易标有日期/时间和客户。
library(data.table)
transactions <- data.table(trans.id = 1:10,
customer.id = c(rep(c('a','b'),3),'c'))
set.seed(42)
transactions[, time := sample(500, 10, T)]
Find.Prior.ID <- function(id.curr) {
trans.curr <- transactions[trans.id == id.curr]
time.curr <- trans.curr[, time]
customer <- trans.curr[, customer.id]
prior.trans <- transactions[
time < time.curr & customer.id == customer]
if (dim(prior.trans)[1] == 0) {return(NA)}
time.prior <- prior.trans[,max(time)]
id.prior <- prior.trans[
time == time.prior,
trans.id]
return(id.prior)
}
transactions[, prior.id := unlist(lapply(
X = trans.id, FUN = Find.Prior.ID))]
prior.id
填充一个简单的合并允许我映射我想要的任何其他信息。我的问题真的归结为运行时间。这种结构的运行时间很长。有没有办法更快地做到这一点?
setorder(transactions, time)
transactions[, prior.id:=c(NA,trans.id[-.N]), by=customer.id]
最佳答案
在 data.table
版本1.9.5
有一个新的shift
接受参数的函数 type = lag
用于计算滞后变量。
transactions[, prior.id := shift(trans.id, type = "lag"), by = customer.id]
关于r - 从 R 中的先前观察中查找信息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30161220/
我的应用将 SceneKit 内容的“页面”与图像和文本交替。当我从图像页面前进到新的 SceneKit 页面时,前一个 SceneKit 页面中的内容会短暂显示,然后被新内容替换。时髦。 我只使用一
我正在尝试处理(在 C# 中)包含一些数字数据的大型数据文件。给定一个整数数组,如何对其进行拆分/分组,以便如果下一个 n(两个或更多)是负数,则前一个 n 元素被分组。例如,在下面的数组中,应该使用
刚接触promises,研究过。所以我的代码和我的理解: sql.connect(config).then(function(connection) { return connection.req
目前我在 if (roobaf) block 中有一些代码,这取决于 foo 和 bar 是否为假。我可以在 block 内再次检查这些条件,但感觉像是不必要的代码重复。 if (foo) {
我是一名优秀的程序员,十分优秀!