将数据帧转换为json

use*_*980 29 json r rjson

我有一个数据框,我想转换为json格式:

我的数据框叫做res1:

library(rjson)

structure(list(id = c(1, 2, 3, 4, 5), value = structure(1:5, .Label = c("server1", 
"server2", "server3", "server4", "server5"), class = "factor")), .Names = c("id", 
"value"), row.names = c(NA, -5L), class = "data.frame")
Run Code Online (Sandbox Code Playgroud)

当我做:

toJSON(res1)
Run Code Online (Sandbox Code Playgroud)

我明白了:

{"id":[1,2,3,4,5],"value":["server1","server2","server3","server4","server5"]}
Run Code Online (Sandbox Code Playgroud)

我需要这个json输出是这样的,任何想法?

[{"id":1,"value":"server1"},{"id":2,"value":"server2"},{"id":3,"value":"server3"},{"id":4,"value":"server4"},{"id":5,"value":"server5"}]
Run Code Online (Sandbox Code Playgroud)

nyc*_*ler 47

所述jsonlite包存在就是为了解决这个问题:"JSON数据和R对象之间的实际和一致的映射"

它的toJSON功能使用默认选项提供所需的结果:

library(jsonlite)
x <- toJSON(res1)
cat(x)

## [{"id":1,"value":"server1"},{"id":2,"value":"server2"},
## {"id":3,"value":"server3"},{"id":4,"value":"server4"},
## {"id":5,"value":"server5"}]
Run Code Online (Sandbox Code Playgroud)


MrF*_*ick 21

怎么样

library(rjson)
x <- toJSON(unname(split(res1, 1:nrow(res1))))
cat(x)
# [{"id":1,"value":"server1"},{"id":2,"value":"server2"},
# {"id":3,"value":"server3"},{"id":4,"value":"server4"},
# {"id":5,"value":"server5"}]
Run Code Online (Sandbox Code Playgroud)

通过使用split()我们基本上将大型data.frame拆分为每行的单独data.frame.通过从结果列表中删除名称,toJSON函数将结果包装在数组中而不是命名对象中.


Jar*_*ber 6

现在您可以轻松地jsonlite::write_json()直接调用数据框。

  • `read_json` 和 `write_json` 设计用于从磁盘读取/写入。`jsonlite::toJSON(res1)` 仍然是这个问题的正确答案。 (6认同)