2015-04-07 2 views
1

У меня есть следующие кадр данных:Как вставить новый столбец в кадре данных с едиными значениями

> head(mtcars) 
        mpg cyl disp hp drat wt qsec vs am gear carb 
Mazda RX4   21.0 6 160 110 3.90 2.620 16.46 0 1 4 4 
Mazda RX4 Wag  21.0 6 160 110 3.90 2.875 17.02 0 1 4 4 
Datsun 710  22.8 4 108 93 3.85 2.320 18.61 1 1 4 1 
Hornet 4 Drive 21.4 6 258 110 3.08 3.215 19.44 1 0 3 1 
Hornet Sportabout 18.7 8 360 175 3.15 3.440 17.02 0 0 3 2 
Valiant   18.1 6 225 105 2.76 3.460 20.22 1 0 3 1 

То, что я хочу сделать, это вставить новые столбцы, называемые «new_column» со значениями «Foo» в результате этого:

    new_column mpg cyl disp hp drat wt qsec vs am gear carb 
Mazda RX4   foo  21.0 6 160 110 3.90 2.620 16.46 0 1 4 4 
Mazda RX4 Wag  foo  21.0 6 160 110 3.90 2.875 17.02 0 1 4 4 
Datsun 710   foo  22.8 4 108 93 3.85 2.320 18.61 1 1 4 1 
Hornet 4 Drive  foo  21.4 6 258 110 3.08 3.215 19.44 1 0 3 1 
Hornet Sportabout foo  18.7 8 360 175 3.15 3.440 17.02 0 0 3 2 
Valiant    foo  18.1 6 225 105 2.76 3.460 20.22 1 0 3 1 

Я попытался это, но не смог:

library(zoo) 
zoo("foo",mtcars$new_columns) 

Что это правильный путь т сделать это?

ответ

3

Вы можете просто использовать cbind (если позиция столбца должна быть первой):

head(cbind("new_column" = "foo", mtcars)) 
#     new_column mpg cyl disp hp drat wt qsec vs am gear carb 
# Mazda RX4    foo 21.0 6 160 110 3.90 2.620 16.46 0 1 4 4 
# Mazda RX4 Wag   foo 21.0 6 160 110 3.90 2.875 17.02 0 1 4 4 
# Datsun 710    foo 22.8 4 108 93 3.85 2.320 18.61 1 1 4 1 
# Hornet 4 Drive   foo 21.4 6 258 110 3.08 3.215 19.44 1 0 3 1 
# Hornet Sportabout  foo 18.7 8 360 175 3.15 3.440 17.02 0 0 3 2 
# Valiant     foo 18.1 6 225 105 2.76 3.460 20.22 1 0 3 1 

Если столбец может быть в конце концов, вы также можете сделать:

mtcars$new_column <- "foo" 
Смежные вопросы