使特定列成为r中的标题(重塑/转置)

时间:2018-06-06 09:47:36

标签: r reshape transpose

我正在尝试做一些非常简单的事情,但在网上找不到任何东西(而且我发现很难知道谷歌的内容)。

我的数据集示例如下。

TimeDiff      Speed       Direction
   3            0              0
   2            0             10
  54            0             15 
  36            0             20

我想重新整形数据框,如下所示。

              0      10      15     20
TimeDiff      3      2       54     36
Speed         0      0       0      0

所以我基本上想让方向列成为我的标题和timediff并加快我的行速度。

感谢您提供的任何帮助。

1 个答案:

答案 0 :(得分:1)

这个怎么样?

setNames(data.frame(t(df)[-ncol(df), ]), as.character(df[, ncol(df)]))
#         0 10 15 20
#TimeDiff 3  2 54 36
#Speed    0  0  0  0

这会生成data.frameint列。

str(setNames(data.frame(t(df)[-ncol(df), ]), as.character(df[, ncol(df)])))
#'data.frame':  2 obs. of  4 variables:
# $ 0 : int  3 0
# $ 10: int  2 0
# $ 15: int  54 0
# $ 20: int  36 0