【问题标题】:Combine rows by id making vectors通过 id 制作向量来组合行
【发布时间】:2023-11-28 15:38:01
【问题描述】:
我无法转换这个:
Name(id) Food
John Apple
John Beans
Anna Apple
Anna Banana
到这里:
Name(id) Food
John c(Apple,Beans)
Anna c(Apple,Banana)
我找到了解决 Python 类似问题的方法:
Combine rows by id
但不能在 R 上做类似的事情。
【问题讨论】:
标签:
r
dataframe
vector
rows
【解决方案1】:
# import necessary package
library(dplyr)
# reproduce the data
df <- data_frame(
`Name(id)` = c("John", "John", "Anna", "Anna"),
Food = c("Apple", "Beans", "Apple", "Banana")
)
# group by name and store food in a list
df2 <- df %>%
group_by(`Name(id)`) %>%
summarise(Food = list(Food))
df2
# # A tibble: 2 x 2
# `Name(id)` Food
# <chr> <list>
# 1 Anna <chr [2]>
# 2 John <chr [2]>