全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 R语言论坛
2109 4
2015-08-05
我有一组数据 (df)

id   value
1     15
1     20
1     21
1     6
1     52
2     18
2     93
2     6

现在想把每个id/组里的最后一个数据用新数字代替。上面这个例子两个id里,最后一个数字分别是52和6,我想用17和3分别代替。 我试了“dplyr” 这个package,用了如下命令:
df %>%  group_by(id) %>%  mutate(value = replace(value, n(), c(17,3)))

做不出来。

请问谁有更好的办法?多谢。
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

全部回复
2015-8-5 10:27:31
复制代码


二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2015-8-5 12:30:22
library(data.table)
index = setDT(df)[, .I[.N], by = .(id)]$V1
df[index, value := 0L]

dplyr是分组计算,你用两个数字替代一个数字不行。
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2015-12-26 08:46:47
十里春风 发表于 2015-8-5 10:27
十分感谢。
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2015-12-26 08:47:45
rosenbloog 发表于 2015-8-5 12:30
library(data.table)
index = setDT(df)[, .I[.N], by = .(id)]$V1
df
十分感谢。
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

相关推荐
栏目导航
热门文章
推荐文章

说点什么

分享

扫码加好友,拉您进群
各岗位、行业、专业交流群