【问题标题】:Reading XML elements content with DOM4J使用 DOM4J 读取 XML 元素内容
【发布时间】:2013-06-11 18:38:56
【问题描述】:

我需要一些帮助。

我有以下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&lt;String&gt; 中,如下所示:{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);
}

我尝试打印 tempAL 的内容,输出如下:

[






  , 



  , 



  ]
  [






  , 



  , 



  ]
  [






  , 



  , 



  ]

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

【问题讨论】:

    标签: java xml xml-parsing dom4j


    【解决方案1】:

    问题是您只遍历 simulation 的子代。换句话说,您只查看 3 个 member 元素而不是它们的子元素。

    存储在 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()); 
            }
        }
    

    【讨论】:

    • 嗨,我在代码的第二行遇到错误(“Element element = (Element) i.next();”),它以可转换类型显示。而且我有类型转换((Iterator)root.elementIterator()),否则会出错。你能帮帮我吗
    【解决方案2】:
    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());
     }                  
    }
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2013-10-06
      • 1970-01-01
      • 2023-03-26
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多