gpt4 book ai didi

json - 使用 jsonlite 将 R 中的未命名列表写入 json 数组

转载 作者:行者123 更新时间:2023-12-04 16:31:29 25 4
gpt4 key购买 nike

我正在向想要使用的 C# 开发人员发送数据 http://json2csharp.com/将我的数据字符串转换为对象数组。我认为 jsonlite 包对此有好处,但他没有得到他想要的结果,当我检查生成的输出时,它并不是我所期望的。我对这种情况的解释是产生的输出

x <- list( 
a=list( a=1,b='x',c=list("Foo","Bar"), d=as.Date("2015-01-01") ),
b=list( a=2,b='y',c=list("Hello","World"), d=as.Date("2014-12-31") ),
c=list( a=3,b='z',c=NULL, d=as.Date("2016-02-29") )
)
toJSON(x, pretty = FALSE )

曾是
{"a":{"a":[1],"b":["x"],"c":[["Foo"],["Bar"]],"d":["2015-01-01"]},"b":{"a":[2],"b":["y"],"c":[["Hello"],["World"]],"d":["2014-12-31"]},"c":{"a":[3],"b":["z"],"c":{},"d":["2016-02-29"]}} 

它将所有子元素数据放入列表中,同时将父命名列表视为命名元素的对象。 R 没有为 JSON 设计的相同类型的类型,所以这可能是 toJSON 的预期行为,但我想要更像
[{"a":1,"b":"x","c":["Foo","Bar"],"d":"2015-01-01"},{"a":2,"b":"y","c":["Hello","World"],"d":"2014-12-31"},{"a":3,"b":"z","c":{},"d":"2016-02-29"}] 

如何将 R 中的列表写入 jsonlite 中的 JSON 数组?

最佳答案

所以事实证明,取消列表的命名和设置 auto_unbox 正是我想要的。将代码更改为:

x2 <- list( 
list( a=1,b='x',c=list("Foo","Bar"), d=as.Date("2015-01-01") ),
list( a=2,b='y',c=list("Hello","World"), d=as.Date("2014-12-31") ),
list( a=3,b='z',c=NULL, d=as.Date("2016-02-29") )
)
toJSON(x2, auto_unbox = TRUE, pretty = FALSE )

或者
x2 <- unname(x)
toJSON(x2, auto_unbox = TRUE, pretty = FALSE )

导致了我正在寻找的对象数组:
[{"a":1,"b":"x","c":["Foo","Bar"],"d":"2015-01-01"},{"a":2,"b":"y","c":["Hello","World"],"d":"2014-12-31"},{"a":3,"b":"z","c":{},"d":"2016-02-29"}] 

不过,我无法说出它们的名字。

关于json - 使用 jsonlite 将 R 中的未命名列表写入 json 数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32102276/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com