如何插入一个新列有统一的数据帧值

问题描述:

,我有以下的数据帧:如何插入一个新列有统一的数据帧值

> 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”与值“富” 新列造成这样的:

    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) 

什么是正确的方式ŧ o做到了吗?

你可以使用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"