import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
import org.dom4j.tree.DefaultAttribute;
/**
* Java递归遍历XML所有元素
*
* @author Administrator
* @version [版本号, Apr 13, 2010]
* @see [相关类/方法]
* @since [产品/模块版本]
*/
public class XmlParser
{
// private static Map xmlmap = new HashMap();
//存储xml元素信息的容器
private static ArrayList<Leaf> elemList = new ArrayList<Leaf>();
public static void main(String args[])
throws DocumentException
{
XmlParser test = new XmlParser();
String path = "C:/a.xml";
// 读取XML文件
SAXReader reader = new SAXReader();
Document doc = reader.read(path);
// 获取XML根元素
Element root = doc.getRootElement();
test.getElementList(root);
String x = test.getListString(elemList);
System.out.println("-----------解析结果------------\n" + x);
}
/**
* 获取节点所有属性值
* <功能详细描述>
* @param element
* @return
* @see [类、类#方法、类#成员]
*/
public String getNoteAttribute(Element element)
{
String xattribute = "";
DefaultAttribute e = null;
List list = element.attributes();
for (int i = 0; i < list.size(); i++)
{
e = (DefaultAttribute)list.get(i);
//System.out.println("name = " + e.getName() + ", value = " + e.getText());
xattribute += " [name = " + e.getName() + ", value = " + e.getText() + "]";
}
return xattribute;
}
/**
* 递归遍历方法
* <功能详细描述>
* @param element
* @see [类、类#方法、类#成员]
*/
public void getElementList(Element element)
{
List elements = element.elements();
// 没有子元素
if (elements.isEmpty())
{
String xpath = element.getPath();
String value = element.getTextTrim();
elemList.add(new Leaf(getNoteAttribute(element), xpath, value));
}
else
{
// 有子元素
Iterator it = elements.iterator();
while (it.hasNext())
{
Element elem = (Element)it.next();
// 递归遍历
getElementList(elem);
}
}
}
public String getListString(List elemList)
{
StringBuffer sb = new StringBuffer();
for (Iterator it = elemList.iterator(); it.hasNext();)
{
Leaf leaf = (Leaf)it.next();
sb.append("xpath: " + leaf.getXpath()).append(", value: ").append(leaf.getValue());
if (!"".equals(leaf.getXattribute()))
{
sb.append(", Attribute: ").append(leaf.getXattribute());
}
sb.append("\n");
}
return sb.toString();
}
}
/**
* xml节点数据结构
*/
class Leaf
{
// 节点属性
private String xattribute;
// 节点PATH
private String xpath;
// 节点值
private String value;
public Leaf(String xattribute, String xpath, String value)
{
this.xattribute = xattribute;
this.xpath = xpath;
this.value = value;
}
public String getXpath()
{
return xpath;
}
public void setXpath(String xpath)
{
this.xpath = xpath;
}
public String getValue()
{
return value;
}
public void setValue(String value)
{
this.value = value;
}
public String getXattribute()
{
return xattribute;
}
public void setXattribute(String xattribute)
{
this.xattribute = xattribute;
}
}
分享到:
相关推荐
针对这一问题,"遍历XML文件内所有节点和属性"的非递归方法应运而生。 在描述中提到的“比递归调用的速度要快很多”,这通常是指通过迭代而非递归的方式遍历XML文档。递归方法会为每个节点创建新的函数调用栈,而当...
用java递归dom解析器解析遍历Xml文档
本篇文章将深入探讨如何使用Java递归地读取XML文件。 首先,我们需要了解XML的基本结构。XML(eXtensible Markup Language)是一种标记语言,它的层次结构由元素(Element)、属性(Attribute)以及文本内容(Text ...
总之,"JAVA递归DEMO"是一个关于使用Java递归遍历XML文档所有元素的示例。通过理解递归的概念和XML的结构,开发者可以有效地解析和操作XML数据。这个DEMO对于学习和实践Java XML处理技巧非常有帮助。
以下是一个使用递归和DOM来遍历XML文档的Java代码示例: ```java package com.dowebber.xmlreader; import java.io.File; import java.io.IOException; import javax.xml.parsers.DocumentBuilder; import javax....
在Java编程中,遍历文件夹和解析XML是两种常见的操作,它们在处理数据和构建应用程序时发挥着关键作用。这篇文档"java遍历文件夹解析XML.doc"可能详细介绍了如何使用Java进行这两个任务。 首先,让我们深入了解一下...
如果XML结构复杂,可以递归遍历子节点,直到找到所需的数据。 此外,JAXB(Java Architecture for XML Binding)是另一种强大的工具,它可以将XML与Java对象直接映射,方便数据的序列化和反序列化。对于多级XML,...
接下来,我们可以递归地遍历XML结构,访问每个元素节点及其属性: ```java void traverse(Element element) { // 访问元素的属性 for (Attribute attr : element.attributes()) { System.out.println("属性名: ...
我们可以从根元素开始,递归遍历整个XML结构。 ```java NodeList nodeList = doc.getElementsByTagName("*"); // 获取所有元素 for (int i = 0; i (); i++) { Node node = nodeList.item(i); // 处理节点,如获取...
解析完成后,我们获取XML文档的根节点,并使用`traverseDOM`递归函数遍历所有子节点。每个节点的名称都会被打印出来。 注意,由于Xerces-C++使用的是宽字符,因此在输出节点名称时,我们需要使用`XMLString::...
对于JavaBean,我们需要预先定义一个类,该类的字段与XML元素相对应,且设置方法用于接收解析出的数据。 例如,假设我们有一个XML文件,内容如下: ```xml <name>John Doe <age>30 <name>Jane Doe ...
// 如果是目录,递归遍历 if (file.isDirectory()) { listAllFilesOnSdCard(file); } } } else { Log.d("FileInfo", "No files or directories found on SD card."); } } ``` 这段代码会打印出SD卡上每个...
这部分可能会详细解释如何使用递归遍历XML树,以及如何通过DOM和SAX解析XML。 "无废话XML"很可能是对XML简洁性和实用性的强调,强调在编写XML时避免不必要的复杂性,提高代码可读性和维护性。这部分可能包括最佳...
此外,`traverseDOM`方法用于递归遍历整个XML文档,打印出元素名称和文本内容以及所有属性。 Axiom库提供了丰富的API,可以方便地操作XML文档,如创建、修改、删除元素、属性等。在实际项目中,我们可以根据需求...
`xmlToMap`方法首先使用SAXReader解析XML字符串,然后递归地遍历XML文档的元素,将它们转换为Map结构。 `mapToXml`方法则将Map转换成XML字符串: ```java import org.dom4j.Document; import org.dom4j....
4. **递归算法**:在递归函数中,遍历每一层级的数据,如果当前数据有子项,则创建子节点并继续递归,直到所有数据都转化为XML节点。 5. **输出XML**:完成XML树构建后,使用JDom的相应方法将XML树写入文件,生成...
例如,每个XML元素的标签名作为键,元素的文本内容作为值。如果元素有子元素,那么可以创建嵌套的Map结构。`EasyXmlUtil`中很可能包含了一个名为`xmlToMap`的方法,用于执行这个过程。 接下来,Map到XML的转换则...
递归意味着函数调用自身来处理XML元素的子节点,直到所有节点都被遍历并转换为Map结构。 以下是一个简化的递归XML转Map的步骤: 1. **解析XML**:首先,你需要使用Java的内置库如`javax.xml.parsers....
4. **遍历XML节点**:可以使用迭代器或者递归遍历XML文档中的元素。 ```java NodeList nodeList = document.getElementsByTagName("tag_name"); for (int i = 0; i (); i++) { Node node = nodeList.item(i); if ...