【问题标题】: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]>

【讨论】:

    最近更新 更多