按组在R数据表/框中,将先前行值的总比率与当前行值的不同列相加。
创始人
2024-09-03 06:01:10
0

可以使用数据表的滑动窗口函数(shift())来计算先前行值及总和,并应用查询(.SD)操作将这些计算过程应用于数据表的每个组。然后,可以将这些计算过程应用于当前行值,从而计算总比率,并将其添加为新列。 以下是示例代码:

library(data.table)

# 创建示例数据表
dt <- data.table(ID = c(rep(1, 4), rep(2, 4)),
                 Value = c(10, 20, 30, 40, 5, 10, 15, 20))

# 按ID分组并添加滑动窗口列
dt[, c("PrevSum", "PrevCount") := .(shift(cumsum(Value), fill = 0), 
                                    shift(seq_along(Value), fill = 0)), 
   by = ID]

# 计算总比率并添加到数据表中
dt[, Ratio := sum(PrevSum)/sum(Value), by = ID]
dt

这将生成以下输出:

   ID Value PrevSum PrevCount     Ratio
1:  1    10       0         0 0.2222222
2:  1    20      10         1 0.2222222
3:  1    30      30         2 0.2222222
4:  1    40      60         3 0.2222222
5:  2     5       0         0 0.2941176
6:  2    10       5         1 0.2941176
7:  2    15      15         2 0.2941176
8:  2    20      30         3 0.2941176

其中PrevSumPrevCount是基于先前行值的计算过

相关内容

热门资讯

八分钟了解!一起宁德游戏钓蟹输... 八分钟了解!一起宁德游戏钓蟹输赢规律,白金岛跑得快辅助工具,黑科技教程(有挂脚本)小薇(透视辅助)致...
8分钟了解!衡阳丫丫字牌外 挂... 8分钟了解!衡阳丫丫字牌外 挂,拱趴大菠萝切牌规律,wpk教程(有挂普及)1、完成拱趴大菠萝切牌规律...
八分钟了解!广西跑得快助赢神器... 八分钟了解!广西跑得快助赢神器购买,赣牌圈开挂是真的吗,AA德州教程(有挂方法);1、超多福利:超高...
一分钟了解!大凉山生活号跑得快... 一分钟了解!大凉山生活号跑得快有挂吗,哈局十三张安卓辅助,玩家教你(有挂教学)在进入大凉山生活号跑得...
六分钟了解!闽悦麻将是不是有挂... 六分钟了解!闽悦麻将是不是有挂,花花生活圈怎么老是输,教你攻略(有挂工具)花花生活圈怎么老是输辅助器...
一分钟了解!小程序的雀神麻将怎... 一分钟了解!小程序的雀神麻将怎么玩才会赢,中至窝龙如何提高自己的胜率,专业教程(有挂神器)1、在小程...
3分钟了解!皮皮斗地主外 挂,... 3分钟了解!皮皮斗地主外 挂,兴动棋牌麻将有挂吗,解密教程(有挂插件)兴动棋牌麻将有挂吗辅助器中分为...
七分钟了解!胡乐辅助器免费版,... 七分钟了解!胡乐辅助器免费版,掌心圈麻将有挂是真的吗,详细教程(有挂解说)一、掌心圈麻将有挂是真的吗...
8分钟了解!随意玩拼三张能破解... 8分钟了解!随意玩拼三张能破解吗,中至麻将发牌规律,攻略方法(有挂科普)1、玩家可以在随意玩拼三张能...
二分钟了解!蜂娱棋牌2有挂吗,... 二分钟了解!蜂娱棋牌2有挂吗,拱趴十三水输赢规律,德州教程(有挂辅助)1.拱趴十三水输赢规律 ai辅...