如何通过在一列

时间:2016-11-09 22:22:49

标签: r dplyr

我有一个包含20列的数据框。最后一列是文本字段。我想按前19列分组,并连接最后一个文本列的值。 我一直试图通过使用dplyr来实现这一点:

mydf %>%
group_by(col1, col2, col3, ... col19) %>%
summarise(alltasks = c(col20))

但这不起作用并返回此错误消息:

  

eval中的错误(替换(expr),envir,enclos):期待单个   值

我做错了什么?

1 个答案:

答案 0 :(得分:5)

正如@thelatemail所指出的,你需要返回一个值,而不是所有值的向量。以下是如何执行此操作的示例:

dots = lapply(paste0("col", 1:19), as.symbol)

mydf %>%
  group_by_(.dots=dots) %>%
  summarise(alltasks = paste(col20, collapse=", "))

summarise行的更改是将col20中的所有值粘贴到单个字符串中的方式。我使用了逗号空间分隔符,但您当然可以将其更改为您喜欢的任何内容。 dots业务只是一种更简单的方法,可以在不输入每个变量的情况下组合所有分组变量。

如果mydf的名称不是那么规律,您可以使用简单的paste函数来生成它们,那么其他选项就是:

dots = lapply(names(mydf)[1:19], as.symbol)

dots = lapply(names(mydf)[-grep("col20$", names(mydf))], as.symbol)

以下是使用内置dplyr数据框的mtcars代码的工作示例:

dots = lapply(c("am","vs","cyl","carb"), as.symbol)

mtcars %>%
  group_by_(.dots=dots) %>%
  summarise(all_mpg = paste(mpg, collapse=", "))
      am    vs   cyl  carb                      all_mpg
1      0     0     8     2       18.7, 15.5, 15.2, 19.2
2      0     0     8     3             16.4, 17.3, 15.2
3      0     0     8     4 14.3, 10.4, 10.4, 14.7, 13.3
4      0     1     4     1                         21.5
5      0     1     4     2                   24.4, 22.8
6      0     1     6     1                   21.4, 18.1
7      0     1     6     4                   19.2, 17.8
8      1     0     4     2                           26
9      1     0     6     4                       21, 21
10     1     0     6     6                         19.7
11     1     0     8     4                         15.8
12     1     0     8     8                           15
13     1     1     4     1       22.8, 32.4, 33.9, 27.3
14     1     1     4     2             30.4, 30.4, 21.4