R中的包似乎無法在將XML轉換爲JSON時正常工作。我用'XML'軟件包試了RJSONIO,rjson和jsonlite。我首先解析XML並使用XML :: xmlToList()將其轉換爲列表,然後使用這3個包中的toJSON()將它們轉換爲JSON。XML轉換爲JSON R
我的XML文件:
<?xml version="1.0" encoding="utf-8"?>
<votes>
<row Id="1" PostId="1" VoteTypeId="2" CreationDate="2014-05-13T00:00:00.000" />
<row Id="2" PostId="1" VoteTypeId="2" CreationDate="2014-05-13T00:00:00.000" />
<row Id="3" PostId="3" VoteTypeId="2" CreationDate="2014-05-13T00:00:00.000" />
</votes>
我的源代碼:
library(XML)
library(RJSONIO)
library(rjson)
library(jsonlite)
xml_parse <- xmlTreeParse("~/Downloads/test.xml", useInternalNodes=TRUE)
xml_root <- xmlRoot(xml_parse)
xml_list <- xmlToList(xml_root, simplify = TRUE)
#jsonlite package
xml_jsonlite <- jsonlite::toJSON(xml_list)
write(xml_jsonlite, "test_jsonlite.json")
#RJSONIO package
xml_rjsonio <- RJSONIO::toJSON(xml_list)
write(xml_rjsonio, "test_rjsonio.json")
#rjson package
xml_rjson <- RJSONIO::toJSON(xml_list)
write(xml_rjson, "test_rjson.json")
轉換JSON從RJSONIO文件:
{
"row": {
"Id": "98",
"PostId": "10",
"VoteTypeId": "2",
"CreationDate": "2014-05-14T00:00:00.000"
},
"row": {
"Id": "99",
"PostId": "7",
"VoteTypeId": "5",
"UserId": "111",
"CreationDate": "2014-05-14T00:00:00.000"
}
}
這是因爲重複的字段名稱顯然是錯誤的。從jsonlite
轉換JSON文件:
{"row":["1","1","2","2014-05-13T00:00:00.000"],
"row.1":["2","1","2","2014-05-13T00:00:00.000"],
"row.2":["3","3","2","2014-05-13T00:00:00.000"]}
這是奇怪,因爲應該只有一個字段名「行」與子文檔,而不是增加「行」的數組的數組。它甚至沒有字段名稱。從rjson
轉換JSON文件:
{
"row": {
"Id": "1",
"PostId": "1",
"VoteTypeId": "2",
"CreationDate": "2014-05-13T00:00:00.000"
},
"row": {
"Id": "2",
"PostId": "1",
"VoteTypeId": "2",
"CreationDate": "2014-05-13T00:00:00.000"
}
}
理想的JSON文件將是這樣:
{"votes" : {
"row" : [
{
"Id" : "1",
"PostId" : "1",
"VoteTypeId" : "2",
"CreationDate" : "2014-05-13T00:00:00.000"
},
{
"Id" : "2",
"PostId" : "1",
"VoteTypeId" : "2",
"CreationDate" : "2014-05-13T00:00:00.000"
}
]
}
}
尋找解決方案。任何幫助表示讚賞。
顯示您用於獲取錯誤的JSON字符串的代碼以及XML轉換中出現的數據,以便我們可以幫助您正確理解它。 – sconfluentus