Java 使用DOM4J读取XML元素内容
我需要一些帮助 我有以下Java 使用DOM4J读取XML元素内容,java,xml,xml-parsing,dom4j,Java,Xml,Xml Parsing,Dom4j,我需要一些帮助 我有以下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&
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>
我不知道为什么,您能帮我从XML中获取所需的内容吗?package com.XML.example;
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();
}
}
}
导入java.io.File;
导入javax.xml.parsers.DocumentBuilder;
导入javax.xml.parsers.DocumentBuilderFactory;
导入org.w3c.dom.Document;
导入org.w3c.dom.Node;
导入org.w3c.dom.NodeList;
公共类ReadXML{
公共静态void main(字符串argv[]){
试一试{
File fXmlFile=新文件(“sample.xml”);
DocumentBuilderFactory dbFactory=DocumentBuilderFactory
.newInstance();
DocumentBuilder dBuilder=dbFactory.newDocumentBuilder();
documentdoc=dBuilder.parse(fXmlFile);
NodeList nList=doc.getElementsByTagName(“成员”);
对于(int-temp=0;temp
希望这个例子能对你有所帮助。它正在打印您需要的所有值,但如果您需要单个值,也可以在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());
}
}
if(nNode.getNodeType()==Node.ELEMENT\u Node){
元素EEElement=(元素)nNode;
NodeList childNodes=eeElement.getChildNodes();
对于(int x=0;x
问题在于,您只是在迭代模拟的子项。换句话说,您只查看3个成员
元素,而不是它们的子元素
ArrayList中存储的空白是文本(空白、硬返回等),您可以使用这些文本来很好地格式化成员
元素的子节点
您可以通过在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();”)中出现了错误,它以可转换类型表示。我还有typecast((迭代器)root.elementIterator()),否则它会给出错误。你能帮帮我吗
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());
}
}
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());
}
}