楼主: Michael1941
851 2

[问答] 能否用group_by 实现如下功能? [推广有奖]

  • 0关注
  • 1粉丝

已卖:62份资源

硕士生

57%

还不是VIP/贵宾

-

威望
0
论坛币
1092 个
通用积分
3.0300
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
960 点
帖子
73
精华
0
在线时间
222 小时
注册时间
2009-2-28
最后登录
2023-4-19

楼主
Michael1941 发表于 2020-3-5 22:06:09 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
如何同group_by或者其他方法实现如下功能,其实原始数据还有var3,var4…… 如何实现

二维码

扫码加我 拉你入群

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

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


沙发
cheetahfly 在职认证  发表于 2020-3-6 12:21:11
library(tidyverse)
df %>%
  group_by(name) %>%
  arrange(desc(var1), .by_group = TRUE) %>%
  fill(var1) %>%
  arrange(desc(var2), .by_group = TRUE) %>%
  fill(var2) %>%
  ungroup() %>%
  distinct()
  

藤椅
zerofung 学生认证  发表于 2020-3-6 15:08:12
library(tidyverse)
df <- data.frame(name = c("a","a","a","b","c","d","d"),
                 var1 = c("","abc","abc","","","x",""),
                 var2 = c("y","","y","","","","z"))
#先建一个表格
df[df == ""] <- NA
#先转为NA比较好做
df2 <- df %>% group_by(name) %>% summarise_all(function(x) x[!is.na(x)][1])
#summarise的自写函数返回结果必须长度是1(也对,毕竟summarise后每个group行数也只有1)
#当然啦只适用于每个group的每个var只有1个值的情况
# summarise_all可以用于你说的var3、var4等无数个var的情况,舒服!
已有 1 人评分学术水平 热心指数 信用等级 收起 理由
Sunknownay + 3 + 3 + 3 热心帮助其他会员

总评分: 学术水平 + 3  热心指数 + 3  信用等级 + 3   查看全部评分

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

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2026-2-8 01:39