2014-07-14 248 views
0

我使用的是CTA API(http://www.transitchicago.com/developers/bustracker.aspx) ,响应是xml。我想在转换为json后,在我的骨干集合中获取。响应看起来是这样的:将xml转换为json格式

<?xml version="1.0"?> 
<bustime-response> 
<route> 
    <rt>1</rt> 
    <rtnm>Bronzeville/Union Station</rtnm> 
    <rtclr>#336633</rtclr> 
</route>   
<route> 
    <rt>2</rt> 
    <rtnm>Hyde Park Express</rtnm> 
    <rtclr>#993366</rtclr> 
</route>   
</bustime-response> 

我想它看起来就像这样:

[ 
    { 
    "rt": "1", 
    "rtnm": "Bronzeville/Union Station", 
    "rtclr": "#336633" 
    }, 
    { 
    "rt": "2", 
    "rtnm": "Hyde Park Express", 
    "rtclr": "#993366" 
    } 
] 

什么是做到这一点的最好方法是什么?

+0

嗯,我假设你正在使用JavaScript,因为你已经添加的标签是JavaScript的最简单的方法要做到这一点是使用谷歌饲料https://developers.google.com/feed/v1/reference,或者你可以参考堆栈溢出问题http://stackoverflow.com/questions/246577/can-i-serve-rss -in-JSON –

回答

0

试试这个功能,它的工作很适合我:

xmlToJson = function(xml) { 
var obj = {}; 
if (xml.nodeType == 1) {     
    if (xml.attributes.length > 0) { 
     obj["@attributes"] = {}; 
     for (var j = 0; j < xml.attributes.length; j++) { 
      var attribute = xml.attributes.item(j); 
      obj["@attributes"][attribute.nodeName] = attribute.nodeValue; 
     } 
    } 
} else if (xml.nodeType == 3) { 
    obj = xml.nodeValue; 
}    
if (xml.hasChildNodes()) { 
    for (var i = 0; i < xml.childNodes.length; i++) { 
     var item = xml.childNodes.item(i); 
     var nodeName = item.nodeName; 
     if (typeof (obj[nodeName]) == "undefined") { 
      obj[nodeName] = xmlToJson(item); 
     } else { 
      if (typeof (obj[nodeName].push) == "undefined") { 
       var old = obj[nodeName]; 
       obj[nodeName] = []; 
       obj[nodeName].push(old); 
      } 
      obj[nodeName].push(xmlToJson(item)); 
     } 
    } 
} 
return obj; 
} 

var jsonText = JSON.stringify(xmlToJson(xmlDoc)); 

对于下面的链接了解更多信息检查

http://davidwalsh.name/convert-xml-json