将一列的每个唯一值分成不同的列并删除原始列?

时间:2019-02-09 04:14:36

标签: r

使用数据框mtcars,如何制作一个新数据框,使用数据框中除gear以外的所有列?在新的数据框中,我想将每个唯一的gear值分成一列。我该怎么办?

3 个答案:

答案 0 :(得分:2)

这将满足您的所有要求


library(fastDummies)

# Numerically encode gear column as dummy variables
mt_cars_with_gear_dummy_variables <- fastDummies::dummy_cols(mtcars, select_columns = "gear")


# Remove original gear column
mt_cars_with_gear_dummy_variables[, !names(mt_cars_with_gear_dummy_variables) %in% c("gear")] 


mt_cars_with_gear_dummy_variables

答案 1 :(得分:1)

您可以使用model.matrix一步完成此操作:

model.matrix(~ . + gear - 1, mtcars)

哪个给:

                     mpg cyl  disp  hp drat    wt  qsec vs am gear3 gear4 gear5 carb
Mazda RX4           21.0   6 160.0 110 3.90 2.620 16.46  0  1     0     1     0    4
Mazda RX4 Wag       21.0   6 160.0 110 3.90 2.875 17.02  0  1     0     1     0    4
Datsun 710          22.8   4 108.0  93 3.85 2.320 18.61  1  1     0     1     0    1
Hornet 4 Drive      21.4   6 258.0 110 3.08 3.215 19.44  1  0     1     0     0    1
Hornet Sportabout   18.7   8 360.0 175 3.15 3.440 17.02  0  0     1     0     0    2
...
Maserati Bora       15.0   8 301.0 335 3.54 3.570 14.60  0  1     0     0     1    8
Volvo 142E          21.4   4 121.0 109 4.11 2.780 18.60  1  1     0     1     0    2

答案 2 :(得分:0)

使用选择: 选择(model.matrix,-gear)