楼主: zico9
1885 4

[问答] 请教:如何用不同的值替代每一个分组里面最后一个值? [推广有奖]

  • 0关注
  • 0粉丝

讲师

4%

还不是VIP/贵宾

-

威望
0
论坛币
20522 个
通用积分
113.2500
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
88271 点
帖子
20
精华
0
在线时间
800 小时
注册时间
2007-11-9
最后登录
2024-4-17

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币
我有一组数据 (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)))

做不出来。

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

扫码加我 拉你入群

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

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

关键词:最后一个 如何用 package replace value 如何

沙发
十里春风 学生认证  发表于 2015-8-5 10:27:31 |只看作者 |坛友微信交流群
  1. df<-data.frame(id=c(1,1,1,1,1,2,2,2),value=c(15,20,21,6,52,18,93,6))
  2. df[cumsum(rle(df$id)$lengths),'value']<-c(17,3)
复制代码


使用道具

藤椅
rosenbloog 发表于 2015-8-5 12:30:22 |只看作者 |坛友微信交流群
library(data.table)
index = setDT(df)[, .I[.N], by = .(id)]$V1
df[index, value := 0L]

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

使用道具

板凳
zico9 发表于 2015-12-26 08:46:47 |只看作者 |坛友微信交流群
十里春风 发表于 2015-8-5 10:27
十分感谢。

使用道具

报纸
zico9 发表于 2015-12-26 08:47:45 |只看作者 |坛友微信交流群
rosenbloog 发表于 2015-8-5 12:30
library(data.table)
index = setDT(df)[, .I[.N], by = .(id)]$V1
df
十分感谢。

使用道具

您需要登录后才可以回帖 登录 | 我要注册

本版微信群
加好友,备注cda
拉您进交流群

京ICP备16021002-2号 京B2-20170662号 京公网安备 11010802022788号 论坛法律顾问:王进律师 知识产权保护声明   免责及隐私声明

GMT+8, 2024-4-27 03:11