在数据框的开头插入列

ald*_*ado 5 r arff dataframe

如何将一列添加到 Rdata.frame作为新的第一列,以便所有其他列移动一列?

喜欢:

a|b|c --> new|a|b|c
Run Code Online (Sandbox Code Playgroud)

我需要这样做,因为我希望它row.names成为一个离散的列。这是必需的,因为该write.arff函数将 adata.frame作为输入,但在写入文件时不保留名称。

A5C*_*2T1 6

这已在评论中回答,但为了更清楚地说明有答案,这里有一个小例子:

首先,一些示例数据:

(df <- data.frame(A = 1:2, B = 3:4, row.names = c("row1", "row2")))
#      A B
# row1 1 3
# row2 2 4
Run Code Online (Sandbox Code Playgroud)

来自评论的建议。请注意,原始row.names数据仍然是数据的一部分。

cbind(rn = rownames(df), df)
#        rn A B
# row1 row1 1 3
# row2 row2 2 4
Run Code Online (Sandbox Code Playgroud)

您可以通过row.names = NULLcbind步骤中设置来摆脱它。由于您是cbinding data.frames,您还可以data.frame在必要时将其他参数传递给(例如,stringsAsFactors = FALSE如果您不希望“rn”列是 a factor)。

cbind(rn = rownames(df), df, row.names = NULL)
#     rn A B
# 1 row1 1 3
# 2 row2 2 4
Run Code Online (Sandbox Code Playgroud)