我需要一些帮助。
我有以下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} < / em>的
但是我无法做到这一点。
这是我的代码:
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获得预期的内容吗?
答案 0 :(得分:2)
问题是你只是在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());
}
}
答案 1 :(得分: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());
}
}