使用data.table和RJSONIO / jsonlite - 结果被转置

时间:2015-02-06 18:22:15

标签: r data.table rjsonio jsonlite

我已经实现了rstudio的htmlwidgets的包装库部分,它呈现了一个数据透视表。 该套餐为here

该包适用于data.tables和data.frame(因为它应该!)。例如,它适用于虹膜。 另一方面,如果我尝试将iris转换为data.table我的包(实际上是htmlwidgets - 内部使用RJSONIO)会引发错误。

我知道这似乎很复杂,但您可以通过检查以下代码之间的差异来重现错误:

library(data.table)
library(RJSONIO)
data.table(fromJSON(toJSON(data.table(iris))))

结果与亲爱的虹膜数据集不同:

                                           V1
1:                   5.1,4.9,4.7,4.6,5.0,5.4,
2:                   3.5,3.0,3.2,3.1,3.6,3.9,
3:                   1.4,1.4,1.3,1.5,1.4,1.7,
4:                   0.2,0.2,0.2,0.2,0.2,0.4,
5: setosa,setosa,setosa,setosa,setosa,setosa,

另一方面,jsonlite能够正确地重新构建虹膜(只需记住在运行代码之前分离RJSONIO):

    library(data.table)
    library(jsonlite)
    data.table(fromJSON(toJSON(data.table(iris))))

     Sepal.Length Sepal.Width Petal.Length Petal.Width   Species
  1:          5.1         3.5          1.4         0.2    setosa
  2:          4.9         3.0          1.4         0.2    setosa
  3:          4.7         3.2          1.3         0.2    setosa
  4:          4.6         3.1          1.5         0.2    setosa
  5:          5.0         3.6          1.4         0.2    setosa

我不确定问题是否存在于data.table或RJSONIO ......

1 个答案:

答案 0 :(得分:3)

这与json无关 当RJSONIO::fromJSON返回list时,jsonlite::fromJSON会返回data.frame 它与data.table list之间的呼叫有关,与呼叫data.frame不同,但仍然按预期行事。
在外部通话中尝试as.data.table而不是data.table

as.data.table(fromJSON(toJSON(data.table(iris))))

这已在data.table github上讨论过了。我已在回答您的问题时提及讨论。