Назначьте столбец data.frame с именем строки в R
Я пытаюсь назначить данные существующему файловому фрейму с именем, сгенерированным в цикле. Основным примером может быть
A = data.frame(a = c(1,2,3), b=c(3,6,2))
for (i in 1:2){
name = paste("Name",i, sep="")
assign(name, c(6,3,2))
}
Теперь мне просто нужно выяснить, как добавить name1 и name2 в data.frame A, сохраняя при этом свое назначенное имя. Я уверен, что есть простой ответ, я просто не вижу его прямо сейчас.
в конце концов, я хотел бы закончить с
A
#a b name1 name2
#1 3 6 6
#2 6 3 3
#3 2 2 2
Но мне нужно сделать это автоматическим способом.
Например, если цикл for можно настроить как
for (i in 1:2){
name = paste("Name",i, sep="")
assign(name, c(6,3,2)
A= cbind(A, get(paste(name,i,sep=""))) # works but doesn't maintain the column name as name1 or name2 etc
}
это, однако, не поддерживает имена столбцов
Ответы
Ответ 1
Другие ответы хороши, но если вы настроены на использование цикла, как у вас, это будет работать:
A <- data.frame(a = c(1,2,3), b = c(3,6,2))
for (i in 1:2){
A[paste("Name", i, sep="")] <- c(6,3,2)
}
который дает
> A
a b Name1 Name2
1 1 3 6 6
2 2 6 3 3
3 3 2 2 2
В качестве альтернативы paste("Name", i, sep="")
можно заменить на paste0("Name", i)
Ответ 2
Возможно, вы хотите:
R> A <- data.frame(a=c(1,2,3), b=c(3,6,2))
R> colnames(A) <- paste("Names", 1:ncol(A), sep="")
R> A
Names1 Names2
1 1 3
2 2 6
3 3 2
R>
но, как сказал Тайлер в комментарии, не совсем понятно, что вы просите.
Ответ 3
Все еще не совсем уверен, чего вы пытаетесь выполнить:
A = data.frame(a = c(1,2,3), b=c(3,6,2))
B <- data.frame(A, c(6, 3, 2), c(6, 3, 2))
names(B)[3:4] <- paste0("name", 1:2)
B
Что дает:
a b name1 name2
1 1 3 6 6
2 2 6 3 3
3 3 2 2 2