2013-06-11 42 views
2

我需要一些帮助。用DOM4J读取XML元素内容

我有以下XML文件:

<?xml version="1.0" encoding="UTF-8"?> 

<simulation> 
    <member id="House"> 
    <id>1</id> 
    <agent_name>1</agent_name> 
    <type>1</type> 
    <max_usage>1</max_usage> 
    <min_usage>1</min_usage> 
    <average_usage>1</average_usage> 
    </member> 
    <member id="CSP"> 
    <id>2</id> 
    <agent_name>2</agent_name> 
    <type>2</type> 
    </member> 
    <member id="VPP"> 
    <id>3</id> 
    <agent_name>3</agent_name> 
    <type>3</type> 
    </member> 
</simulation> 

我想要的号码保存到ArrayList<String>这样的:{1,1,1,1,1,1,2,2, 2,3,3,3}

但是我很难做到这一点。

这里是我的代码:

public static void readSimulation(){ 
     Element root = doc.getRootElement(); 
     DefaultListModel tempList = new DefaultListModel(); 
     ArrayList<String> tempAL = new ArrayList(); 

     for (Iterator i = root.elementIterator(); i.hasNext();) { 
      Element element = (Element) i.next(); 
      tempList.addElement(element.attributeValue("id")); 
      tempAL.add(element.getData().toString()); //I think this is the line that doesn't work 
     } 

     pt.ipp.isep.gecad.masgrip.Simulation.setDlm(tempList); 
     pt.ipp.isep.gecad.masgrip.Simulation.setComponentsFromXML(tempAL); 
} 

我tryed打印tempAL的内容和输出是这样的:

[ 






    , 



    , 



    ] 
    [ 






    , 



    , 



    ] 
    [ 






    , 



    , 



    ] 

我不知道为什么,你能帮帮我从XML获取预期的内容?

回答

2

问题是,你只是遍历simulation的孩子。换句话说,你只看着他们的孩子而不是他们的孩子。

存储在ArrayList中的空白空间是用于很好地格式化member元素的子节点的文本(空白区域,硬回车等)。

您可以通过在for循环中添加另一个循环来完成解析。这样的事情:

for (Iterator i = root.elementIterator(); i.hasNext();) { 
     Element element = (Element) i.next(); 
     tempList.addElement(element.attributeValue("id")); 

     for (Iterator j = element.elementIterator(); j.hasNext();) { 
      Element innerElement = (Element) j.next(); 
      tempAL.add(innerElement.getData().toString()); 
     } 
    } 
+0

嗨,我在你的代码的第二行(“元素元素=(元素)i.next();”),它说在可转换类型中出现错误。而且我也有类型转换((Iterator)root.elementIterator()),否则会给出错误。你能帮我解决吗? – TLE

1
package com.xml.example; 

import java.io.File; 

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

import org.w3c.dom.Document; 
import org.w3c.dom.Node; 
import org.w3c.dom.NodeList; 

public class ReadXML { 
    public static void main(String argv[]) { 
     try { 

      File fXmlFile = new File("sample.xml"); 
      DocumentBuilderFactory dbFactory = DocumentBuilderFactory 
        .newInstance(); 
      DocumentBuilder dBuilder = dbFactory.newDocumentBuilder(); 
      Document doc = dBuilder.parse(fXmlFile); 
      NodeList nList = doc.getElementsByTagName("member"); 

      for (int temp = 0; temp < nList.getLength(); temp++) { 

       Node nNode = nList.item(temp); 
       System.out.println("----------------------------"); 
       System.out.println("\nCurrent Element :" + nNode.getNodeName() + " : " + nNode.getTextContent()); 

      } 
     } catch (Exception e) { 
      e.printStackTrace(); 
     } 
    } 
} 

这个例子希望能帮到你。它打印所有你需要的值,但是如果你想要单独的值,你也可以在for循环中使用下面的代码。

if (nNode.getNodeType() == Node.ELEMENT_NODE) { 

    Element eElement = (Element) nNode; 
    NodeList childNodes = eElement.getChildNodes(); 
    for (int x = 0 ; x < childNodes.getLength() ; x++) { 

    System.out.println(childNodes.item(x).getNodeName() + " : " + childNodes.item(x).getTextContent()); 
}     
}