2017-08-01 141 views
0

我有一個包含大量數據的xml文件。我已解析的XML文件,並試圖將值添加到JSON對象,但只有最後一個值越來越added.Please找到我的代碼如下:只有最後一個值被添加到JSON對象

import java.io.BufferedReader; 
import java.io.File; 
import java.io.FileReader; 
import java.util.ArrayList; 
import java.util.HashMap; 
import java.util.Iterator; 

import javax.xml.parsers.DocumentBuilder; 
import javax.xml.parsers.DocumentBuilderFactory; 

import org.json.simple.JSONArray; 
import org.json.simple.JSONObject; 
import org.w3c.dom.Document; 
import org.w3c.dom.Element; 
import org.w3c.dom.Node; 
import org.w3c.dom.NodeList; 

public class Process_Parser { 

static JSONObject json= new JSONObject(); 
//static //JSONObject arrayvalue=new JSONArray(); 

public static void main(String args[]) { 
try { 

File process = new File("/Users/instrument.xml"); 
DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance(); 
DocumentBuilder dBuilder = dbFactory.newDocumentBuilder(); 
Document doc = dBuilder.parse(process); 
doc.getDocumentElement().normalize(); 

//System.out.println("root of xml file" + doc.getDocumentElement().getNodeName()); 
NodeList nodes = doc.getElementsByTagName("process"); 
//System.out.println("=========================="); 

Element pageElement = (Element)doc.getElementsByTagName("process").item(0); 
//NodeList result = pageElement.getElementsByTagName("processName"); 
System.out.println("Suba-----------"+nodes.getLength()); 

for (int i = 0; i < nodes.getLength(); i++) { 
Node node = nodes.item(i); 

if (node.getNodeType() == Node.ELEMENT_NODE) { 
Element element = (Element) node; 
//System.out.println(getValue("processName", element).contains("carkitd")); 
//if(element.getElementsByTagName("process") != null){ 
if(element.getFirstChild().getNodeValue() != null){ 
    if(getValue("processName", element).contains("carkitd")){ 


     json.put("processName",getValue("processName", element)); 
     json.put("cpuUsage",getValue("cpuUsage", element)); 
     json.put("realmemory",getValue("realmemory", element)); 
     json.put("Virtualmemory",getValue("Virtualmemory", element)); 
     json.put("thread",getValue("thread", element)); 
     json.put("cputime",getValue("cputime", element)); 

} 
} 

} 
} 
//System.out.println("result-array:" +arrayvalue); 
System.out.println("result" +json); 
//} 
//System.out.println("arrayvalue::"+arrayvalue.size()); 
}catch (Exception ex) { 
ex.printStackTrace(); 
} 
} 


private static String getValue(String tag, Element element) { 
NodeList nodes = element.getElementsByTagName(tag).item(0).getChildNodes(); 
Node node = (Node) nodes.item(0); 
return node.getNodeValue(); 
} 

} 

當我運行上面的代碼,我得到下面的結果

實際結果:

{ 

"Virtualmemory":"1100320.000000", 
"cpuUsage":"0.000000", 
"process":"carkitd", 
"realmemory":"1044.000000", 
"thread":"2.000000", 
"cputime":"0.000000" 
} 

預期結果:

它應該有67個物體

示例XML文件:

<instrument> 
    <slice time ='1498215480919'> 
     <process> 
      <processId>1.000000</processId> 
      <processName>launchd</processName> 
      <cpuUsage>0.203195</cpuUsage> 
      <realmemory>5084.000000</realmemory> 
      <Virtualmemory>1080112.000000</Virtualmemory> 
      <thread>7.000000</thread> 
      <cputime>0.000000</cputime> 
     </process> 
     <process> 
      <processId>24.000000</processId> 
      <processName>carkitd</processName> 
      <cpuUsage>0.002845</cpuUsage> 
      <realmemory>576.000000</realmemory> 
      <Virtualmemory>1074752.000000</Virtualmemory> 
      <thread>6.000000</thread> 
      <cputime>0.000000</cputime> 
     </process> 
     <process> 
      <processId>24.000000</processId> 
      <processName>carkitd</processName> 
      <cpuUsage>0.002845</cpuUsage> 
      <realmemory>576.000000</realmemory> 
      <Virtualmemory>1074752.000000</Virtualmemory> 
      <thread>6.000000</thread> 
      <cputime>0.000000</cputime> 
     </process> 
    </slice> 
    </instrument> 

我失去了一些東西?

+0

通過在for循環中創建對象並在對象填充後將對象添加到數組中,使用'JSONObject'的'JSONArray' –

回答

0

創建JSONArray,並保持你插入的JSONObject循環內。

JSONArray finalArray = new JSONArray(); // create your jsonarray 
for (int i = 0; i < nodes.getLength(); i++) { 
    Node node = nodes.item(i); 

    if (node.getNodeType() == Node.ELEMENT_NODE) { 
     Element element = (Element) node; 
     //System.out.println(getValue("processName", element).contains("carkitd")); 
     //if(element.getElementsByTagName("process") != null){ 
     if (element.getFirstChild().getNodeValue() != null) { 
      if (getValue("processName", element).contains("carkitd")) { 
       JSONObject json = new JSONObject(); // your temp obj 

       json.put("processName", getValue("processName", element)); 
       json.put("cpuUsage", getValue("cpuUsage", element)); 
       json.put("realmemory", getValue("realmemory", element)); 
       json.put("Virtualmemory", getValue("Virtualmemory", element)); 
       json.put("thread", getValue("thread", element)); 
       json.put("cputime", getValue("cputime", element)); 
       finalArray.put(json); // push your values in the array 
      } 
     } 

    } 
} 
//System.out.println("result-array:" +arrayvalue); 
System.out.println("result " + finalArray); 
0

你寫了:

json.put("processName",getValue("processName", element)); 
json.put("cpuUsage",getValue("cpuUsage", element)); 
json.put("realmemory",getValue("realmemory", element)); 
json.put("Virtualmemory",getValue("Virtualmemory", element)); 
json.put("thread",getValue("thread", element)); 
json.put("cputime",getValue("cputime", element)); 

物權法tlike一個Map,這個覆蓋值,如果它已經存在。在每一次迭代中,您只需重寫您的JSON對象。

您應該在每次迭代中創建一個新的JSONObject並將其存儲在JSONArray中。

0

您可以參考我的問題here以便於實施。

你可以通過stleary使用JSON-java庫。

您可以使用以下代碼將XML字符串轉換爲JSONObject。

JSONObject data = XML.toJSONObject(xmlString);

你可以在這裏找到更多關於它:JSON-java

通過以上參考,我能夠實現在least.I解決方案希望這會爲他人正常工作。

private static JSONObject extractData(NodeList nodeList, String tagName) throws TransformerConfigurationException, 
     TransformerException, TransformerFactoryConfigurationError, JSONException { 
    JSONObject resultObject = new JSONObject(); 
    for (int i = 0; i < nodeList.getLength(); i++) { 
     Node node = nodeList.item(i); 
     if (!node.getNodeName().equals(tagName) && node.hasChildNodes()) { 
      return extractData(node.getChildNodes(), tagName); 
     } else if (node.getNodeName().equals(tagName)) { 
      DOMSource source = new DOMSource(node); 
      StringWriter stringResult = new StringWriter(); 
      TransformerFactory.newInstance().newTransformer().transform(source, new StreamResult(stringResult)); 
      resultObject = XML.toJSONObject(stringResult.toString()).optJSONObject(tagName); 
     } 
    } 
    return resultObject; 
} 

public static JSONObject getFullData(String tagName, SOAPMessage message) throws Exception { 
    NodeList nodeList = message.getSOAPBody().getChildNodes(); 
    JSONObject resultObject = extractData(nodeList, tagName); 
    return resultObject; 
} 

對於你的情況只是初始化JSON內環路

json = new JSONObject(); 
相關問題