【发布时间】:2013-01-27 17:45:35
【问题描述】:
我有一个 DF,我想在第二个位置添加一个名为“B”的新变量。
A C D
1 1 5 2
2 3 3 7
3 6 2 3
4 6 4 8
5 1 1 2
有人有想法吗?
【问题讨论】:
-
DF$B <- newvariable? -
变量的顺序看起来像 A C D B。我想要的顺序是 A B C D
标签: r
我有一个 DF,我想在第二个位置添加一个名为“B”的新变量。
A C D
1 1 5 2
2 3 3 7
3 6 2 3
4 6 4 8
5 1 1 2
有人有想法吗?
【问题讨论】:
DF$B <- newvariable ?
标签: r
dat$B <- 1:5
ind <- c(1:which(names(data) == "A"),ncol(data),(which(names(data) == "A")+1):ncol(data)-1)
data <- data[,ind]
在 data.frame 的末尾创建变量,然后使用指示符向量指示如何重新排序列。 ind 只是一个数字向量
【讨论】:
(ncol(data)-1)。如果您忘记了额外的括号,A 列会得到 A.1 的副本。
最简单的方法是添加所需的列,然后重新排序:
dat$B <- 1:5
newdat <- dat[, c("A", "B", "C", "D")]
另一种方式:
newdat <- cbind(dat[1], B=1:5, dat[,2:3])
如果您担心开销,也许是data.table 解决方案? (在this answer的帮助下):
library(data.table)
dattable <- data.table(dat)
dattable[,B:=1:5]
setcolorder(dattable, c("A", "B", "C", "D"))
【讨论】: