2016-02-18 69 views
0

我想在Java中读取XML,但由于XML中对称元素不对,无法读取 - 还有,如何检查节点是否可用或不如何通过Java 1.6读取XML中的第三层节点

这是XML的

<?xml version="1.0" encoding="UTF-8"?> 
<Root> 
    <node-path path="USA"> 
     <property-name>Name</property-name> 
     <property-value><![CDATA[Cat A]]></property-value> 
     </node-path> 
    <node-path path="Canada"> 
     <property-name>Name</property-name> 
     <property-value /> 
    </node-path> 
    <node-path path="Australia"> 
     <property-name>Name</property-name> 
     <json-counter>1</json-counter> 
     <json-property><![CDATA[Cat A]]></json-property> 
     <json-property><![CDATA[Cat B]]></json-property> 
     <json-property><![CDATA[Cat C]]></json-property> 
     <json-counter>2</json-counter> 
     <json-property><![CDATA[Cat D]]></json-property> 
     <json-property><![CDATA[Cat E]]></json-property> 
     <json-property><![CDATA[Cat F]]></json-property> 
     <property-value /> 
    </node-path> 
    <node-path path="UK"> 
     <property-name>Name</property-name> 
     <property-value><![CDATA[0]]></property-value> 
    </node-path> 
</Root>` 

这是代码我trying-

try {  
    File inputFile = new File("c://test.xml"); 
    DocumentBuilderFactory dbFactory =DocumentBuilderFactory.newInstance(); 
    DocumentBuilder dBuilder = dbFactory.newDocumentBuilder(); 
    Document doc = dBuilder.parse(inputFile); 
    doc.getDocumentElement().normalize(); 

    NodeList nListNodePath = doc.getElementsByTagName("node-path"); 

    for (int i = 0; i < nListNodePath.getLength(); i++) { 
     Node nNodePath = nListNodePath.item(i); 
     if (nNodePath.getNodeType() == Node.ELEMENT_NODE) { 
      Element eElement1 = (Element) nNodePath; 
      System.out.println("Node Path--- : "+ eElement1.getAttribute("path")); 
      System.out.println("Property Name : " + eElement1.getElementsByTagName("property-name").item(0).getTextContent()); 
      System.out.println("Property value : " + eElement1.getElementsByTagName("property-value").item(0).getTextContent()); 
      System.out.println("Json Counter : " + eElement1.getElementsByTagName("json-counter").item(0).getTextContent()); 
      System.out.println("JSON property : " + eElement1.getElementsByTagName("json-property").item(0).getTextContent()); 
     } 
    } 
+0

*“无法读取”*是什么意思? – Andreas

+0

我的意思是,我无法在java中读取上述xml –

+0

我刚刚在该XML上运行了您的代码,并且它的读取正常。由于第一个''中没有''元素,因此代码在'getElementsByTagName(“json-counter”)。item(0).getTextContent()'上的NPE上失败了,但这是不同的。 XML解析没有错误。 – Andreas

回答

0

我怎么能检查节点是否可用

getElementsByTagName()返回NodeList,它有一个getLength()方法,该方法将返回0如果未找到元素。

它也将返回一个值比1json-counterjson-property越大,所以硬编码item(0)可能不是你应该做的事情。

此外,使用getElementsByTagName()意味着你提取的元素,无论位置,所以如果json-counterjson-property混合序列具有的意义,你不能使用getElementsByTagName()

+0

什么应该是最好的方法来阅读上面的XML? –

+0

取决于。 “'和''元素的混合顺序是否重要? ---但通常使用'getFirstChild()'和'getNextSibling()'写一个'for'循环来迭代所有的子节点。 – Andreas

+0

是的,订单需要相同... getFirstChild()和getNextSibling() –

0

您可以尝试使用Xpath工厂。您可以轻松将节点转换为元素。

import javax.xml.xpath.XPathFactory; 
. 
. 
. 
XPath xpath = XPathFactory.newInstance().newXPath(); 
Node node = xpath.evaluate("/root/el1/el2[@attr='123']", yourDocOrNode, XPathConstants.NODE); 

xpath.evaluate要么抛出抛出:XPathExpressionException,如果表达式是无效的,或将返回null如果元素不能被发现。

+0

你能解释更多关于如何用xpath读取吗? –