重塑错误 - 无效' row.names'长度

时间:2016-01-20 21:10:48

标签: r reshape

我有以下数据库(广泛形式)," st_all",其中我有两个变量我希望重塑(" P"和" PLC&#34 )。主题的ID是" g_id"。

  g_id study condition sample PLC1 PLC2 PLC3 PLC4 PLC5 PLC6 PLC7 PLC8 PLC9 PLC10 P1 P2 P3 P4 P5 P6 P7 P8 P9 P10
1    1     1         1      1   20   20   20   50   50   20   30   20   50    50  1  2  2  1  2  2  1  1  1   1
2    2     1         1      1   60   70   50   70   60   60   60   70   60    50  1  2  1  1  2  2  1  1  1   1
3    3     1         1      1   80   50   55   58   70   50   80   80   60    65  1  2  2  1  2  2  1  1  1   1
4    4     1         1      1   89   51   59   62   72   60   86   80   61    54  1  1  2  1  2  2  1  1  1   1
5    5     1         1      1   90   50   60   70   80   50   90   80   60    50  1  1  1  1  2  2  1  1  1   1
6    6     1         1      1   95   50   60  100   95   60   50   60   60    55  1  2  2  1  2  2  1  1  1   1

为此,我运行了以下代码:

reshape(st_all,
idvar="g_id",
direction="long",
varying=list(c(5:14),c(15:24)), 
v.names=c("PLC","P")
)

我收到以下错误:

Error in `row.names<-.data.frame`(`*tmp*`, value = paste(d[, idvar], times[1L],  : 
invalid 'row.names' length

我已经找到了答案,但我找不到。

提前致谢。

1 个答案:

答案 0 :(得分:3)

如评论中所述,当您的数据为reshape时,您会遇到tbl函数的问题。

首先使用as.data.frame

reshape(as.data.frame(st_all),
        idvar = "g_id",
        direction = "long",
        varying = list(c(5:14), c(15:24)), 
        v.names = c("PLC","P"))