我有一个带有特定列的数据框,该列由字符列表组成,如下所示:
a <- list("dyspla", c("dyspla", "dyspla"), "carcin",
c("tumour", "dyspla"), character(0), character(0),
c("carcin", "dyspla"), character(0), character(0), "dyspla")
Run Code Online (Sandbox Code Playgroud)
我希望它是一个字符向量,列表中的字符向量如下折叠
c("dyspla","dyspla,dyspla","carcin","tumour,dyspla","carcin,dyspla","dyspla")
Run Code Online (Sandbox Code Playgroud)
paste(a,collapse=" ") 一起崩溃 如何在列表中按向量折叠?
可能的解决方案:
sapply(a[!!lengths(a)], toString)
Run Code Online (Sandbox Code Playgroud)
或具有purrr的is_empty功能:
sapply(a[!sapply(a, purrr::is_empty)], toString)
Run Code Online (Sandbox Code Playgroud)
两者都给:
Run Code Online (Sandbox Code Playgroud)[1] "dyspla" "dyspla, dyspla" "carcin" "tumour, dyspla" "carcin, dyspla" "dyspla"
或者使用paste:
sapply(a[!sapply(a, purrr::is_empty)], paste, collapse = ',')
Run Code Online (Sandbox Code Playgroud)
针对您的评论:
如果要保留空字符,可以执行sapply(a, toString)或sapply(a, paste, collapse = ',')。
| 归档时间: |
|
| 查看次数: |
204 次 |
| 最近记录: |