【发布时间】:2023-04-11 05:30:02
【问题描述】:
我需要将数据框的所有列合并到一个新列中,该列将包含其他列中值的向量(列表)。像这样的
n = c(2, 3, 5)
s = c(3,3,5)
b = c(1,1,1)
df = data.frame(n, s, b)
n s b
1 2 3 1
2 3 3 1
3 5 5 1
我想运行一个命令,给我这样的东西:
n s b v
1 2 3 1 [2,3,1]
2 3 3 1 [3,3,1]
3 5 5 1 [5,5,1]
基本上是这样的
t(as.numeric(df[1,1:3]))
[,1] [,2] [,3]
[1,] 2 3 1
得到我想要的一行,但我不知道如何为所有行添加它。我尝试了各种apply 功能,但没有取得多大成功。
谢谢。
【问题讨论】:
-
df$v <- apply(df, 1, function(x) paste(x, collapse = ', '))怎么样 -
谢谢。我之前尝试过粘贴,但它创建了一个字符串而不是一个向量/数字列表。我需要数字。
-
那么使用
list而不是paste? -
这个可以
df$v <- as.list(as.data.frame(t(df))) -
还有
df$v <- split(as.matrix(df),rownames(df))
标签: r