--------------------------------------------------
DOM4j解析xml
解析XML
--------------------------------------------------
TestXmlUtil.java
package xml;
import java.io.FileNotFoundException;
import org.dom4j.DocumentException;
public class TestXmlUtil {
public static void main(String[] args) {
XmlUtil x = new XmlUtil();
try {
x.build("jbpm4/jpdl/process.jpdl.xml");
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (DocumentException e) {
e.printStackTrace();
}
x.printAllNodes(x.listChildNodes("process/start/transition"));
System.out.println("END");
}
}
--------------------------------------------------
XmlNode.java
package xml;
import org.dom4j.Element;
public class XmlNode {
private String name;
private String fullName;
private String pathName;
private String split = "-->";
private String path = "/";
private Element node;
public String getSplit() {
return split;
}
public void setSplit(String split) {
this.split = split;
}
public String getPath() {
return path;
}
public void setPath(String path) {
this.path = path;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getFullName() {
return fullName;
}
public void setFullName(String fullName) {
StringBuffer buffer = new StringBuffer();
this.recursionFullName(buffer, node);
this.fullName = buffer.toString().substring(0,
buffer.length() - this.split.length());
}
public String getPathName() {
return pathName;
}
public void setPathName(String pathName) {
StringBuffer buffer = new StringBuffer();
this.recursionPathName(buffer, node);
this.pathName = buffer.toString().substring(0,
buffer.length() - this.path.length());
}
public void recursionFullName(StringBuffer buffer, Element node) {
String nodeName = node.getName();
if (node.getParent() == null) {
String temp = nodeName + this.split + buffer.toString();
buffer.delete(0, buffer.length());
buffer.append(temp);
return;
} else {
String temp = nodeName + this.split + buffer.toString();
buffer.delete(0, buffer.length());
buffer.append(temp);
recursionFullName(buffer, node.getParent());
}
}
public void recursionPathName(StringBuffer buffer, Element node) {
String nodeName = node.getName();
if (node.getParent()==null) {
String temp = nodeName + this.path + buffer.toString();
buffer.delete(0, buffer.length());
buffer.append(temp);
return;
} else {
String temp = nodeName + this.path + buffer.toString();
buffer.delete(0, buffer.length());
buffer.append(temp);
recursionPathName(buffer, node.getParent());
}
}
public Element getNode() {
return node;
}
public void setNode(Element node) {
this.node = node;
}
}
--------------------------------------------------
XmlUtil.java
package xml;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.InputStream;
import java.net.URL;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
public class XmlUtil {
private Document document = null;
private Element elementRoot = null;
public String getExpr() {
List<Element> list = this.getRoot().elements();
for (Element e : list) {
if (e.getName().equals("decision")) {
return e.attributeValue("expr");
}
}
return null;
}
public void build(String sourceName) throws FileNotFoundException,
DocumentException {
SAXReader reader = new SAXReader();
document = reader.read(this.getInputStream(sourceName));// 读取XML文档
elementRoot = document.getRootElement();// 声明根元素
}
// 输出所有的孩子节点名字
public void printAllNodes(ArrayList<XmlNode> xmlNodes) {
for (XmlNode xmlNode : xmlNodes) {
System.out.println("node name=" + xmlNode.getNode().getName());
System.out.println("node FullName=" + xmlNode.getFullName());
System.out.println("node PathName=" + xmlNode.getPathName());
for (Iterator it = xmlNode.getNode().attributeIterator(); it
.hasNext();) {
Attribute attribute = (Attribute) it.next();
System.out.print("Attributes Name=");
System.out.println(attribute.getName());
System.out.print("Attributes Text=");
String text = attribute.getText();
System.out.println(text);
}
System.out.println("============================");
}
}
// 取得所有的孩子节点
public ArrayList<XmlNode> listChildNodes(String sourceName) {
ArrayList<XmlNode> xmlNodes = this.listAllNodes(this.getRoot());
for (XmlNode xmlNode : xmlNodes) {
if (xmlNode.getPathName().equals(sourceName)) {
return this.listAllNodes(xmlNode.getNode());
}
}
return new ArrayList<XmlNode>();
}
// 添加一个节点到集合
private void addNode(ArrayList<XmlNode> xmlNodes, Element root) {
if (root.getNodeType() == 1) {
XmlNode xmlNode = new XmlNode();
String nodeName = root.getName();
xmlNode.setNode(root);
xmlNode.setName(nodeName);
xmlNode.setFullName(nodeName);
xmlNode.setPathName(nodeName);
xmlNodes.add(xmlNode);
}
List<Element> list = root.elements();
for (int i = 0; i < list.size(); i++) {
Element node = (Element) list.get(i);
addNode(xmlNodes, node);
}
}
// 取得所有节点
public ArrayList<XmlNode> listAllNodes(Element root) {
ArrayList<XmlNode> xmlNodes = new ArrayList<XmlNode>();
this.addNode(xmlNodes, root);
return xmlNodes;
}
// 转换成InputStream
public InputStream getInputStream(String sourceName)
throws FileNotFoundException {
URL url = this.getClass().getClassLoader().getResource(sourceName);
FileInputStream fis = new FileInputStream(new File(url.getPath()));
return fis;
}
// 取得开始节点
public Element getRoot() {
return this.elementRoot;
}
}
--------------------------------------------------
XmlUtil.java
package workflow.engine.util;
public class XmlUtil {
private Document document = null;
private Element elementRoot = null;
public String getExpr(InputStream is, String type) throws DocumentException {
this.build(is);
List<Element> list = this.getRoot().elements();
for (Element e : list) {
if (e.getName().equals(type)) {
return e.attributeValue("expr");
}
}
return null;
}
public String getExprFromPattern(String expr) {
Pattern pattern = Pattern.compile("^(\\#\\{)(\\D+?)(\\})$");
Matcher matcher = pattern.matcher(expr);
if (matcher.find())
{
return matcher.group(2);
}
return expr;
}
public String getExpr() {
List<Element> list = this.getRoot().elements();
for (Element e : list) {
if (e.getName().equals("decision")) {
return e.attributeValue("expr");
}
}
return null;
}
public void build(InputStream is) throws DocumentException {
SAXReader reader = new SAXReader();
document = reader.read(is);// 读取XML文档
elementRoot = document.getRootElement();// 声明根元素
}
public void build(String sourceName) throws FileNotFoundException,
DocumentException {
SAXReader reader = new SAXReader();
document = reader.read(this.getInputStream(sourceName));// 读取XML文档
elementRoot = document.getRootElement();// 声明根元素
}
// 转换成InputStream
public InputStream getInputStream(String sourceName)
throws FileNotFoundException {
URL url = this.getClass().getClassLoader().getResource(sourceName);
FileInputStream fis = new FileInputStream(new File(url.getPath()));
return fis;
}
// 取得开始节点
public Element getRoot() {
return this.elementRoot;
}
}
分享到:
相关推荐
### DOM4J解析XML详解 #### 一、DOM4J简介与特性 DOM4J是一个由dom4j.org开发的开源XML解析包,专为Java平台设计,它不仅支持DOM、SAX和JAXP标准,还巧妙地融入了Java集合框架,使其成为Java开发者在处理XML数据时...
使用 dom4j 解析 XML dom4j 解析 XML dom4j解析xml
**DOM4J解析XML** DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了灵活、高效且功能丰富的API,使得XML的读取、创建、修改和查询变得简单易行。DOM4J的主要特点包括对XPath的支持、事件驱动的解析、以及与...
### DOM4J解析XML知识点详解 #### 一、DOM4J简介 DOM4J是一个Java库,用于处理XML文档。它的设计目标是为了提供一个简单、易于使用的API来处理XML文件,同时保持性能上的优势。与Java标准库中的DOM实现相比,DOM4J...
Java DOM4J解析XML是一种常见的处理XML文档的技术,它提供了灵活且高效的API,使得开发者能够方便地读取、写入、修改以及操作XML文件。DOM4J是Java中一个非常强大的XML处理库,它结合了DOM、SAX和JDOM的优点,同时也...
在“dom4j解析xml文件(增删改查)”这个主题中,我们将深入探讨如何使用DOM4J来实现XML文档的四种基本操作:增加元素、删除元素、更新元素内容以及查询元素。 首先,让我们了解DOM4J的基本用法。在解析XML文件时,...
**DOM4J解析XML实例详解** 在Java编程中,处理XML文档是一项常见的任务。DOM4J是一个非常流行的、强大的Java XML API,它提供了灵活且高效的方式来解析、创建、修改XML文档。本文将深入探讨如何使用DOM4J进行XML...
在这个实例中,我们将深入探讨如何使用DOM4J解析XML文件,并通过`Dom4jTest1.java`这个示例程序来理解其工作原理。 首先,我们需要了解XML(Extensible Markup Language)是一种标记语言,常用于存储和传输数据。...
本人自己研究的解析方法,主要用dom4j解析XML文件,进而获取里面的信息
通过这种方式,我们可以利用DOM4J解析XML文件,同时借助Java反射机制将解析结果动态地映射到自定义的Java类中。这在处理XML数据时提供了很大的灵活性,尤其在需要将XML数据与业务对象关联时,反射机制显得尤为重要。
在本示例中,我们将深入探讨如何使用DOM4J解析XML文件,以`CacheInit.java`作为我们的核心代码示例,并参考`emailTemplateConfig.xml`作为实际操作的对象。 首先,让我们了解XML(eXtensible Markup Language)。...
1. **DOM4J解析XML**:DOM4J通过创建一个可操作的树形结构来表示XML文档,这棵树称为文档对象模型。解析XML时,DOM4J首先读取XML文件并构建一个节点结构,然后你可以通过API遍历和修改这个结构。例如,你可以通过...
【使用dom4j解析XML】 dom4j是一个强大的开源XML框架,它提供了处理XML文档的各种功能,包括解析、创建、修改等。相比W3C DOM API,dom4j的优势在于其内置的XPath支持,允许更方便地定位和操作XML文档中的节点。 *...
1、xml文档解析 2、 dom4j解析xml 3、实现xml文件解析 xml字符串解析 xml MAP键值对解析 4、实现xml写入与生成文件
为了在Java项目中使用DOM4J解析XML,你需要将这两个jar文件(dom4j-1.6.1和jaxen-1.1-beta-7.jar)添加到你的类路径(classpath)中。这可以通过在IDE中配置构建路径,或者在命令行中指定 `-cp` 参数来完成。一旦...
在本实例中,我们将深入探讨如何使用DOM4J解析XML,并利用这些数据连接Oracle数据库进行数据操作。 首先,让我们了解DOM4J的基本用法。DOM4J的主要类包括`Document`、`Element`、`Attribute`和`Namespace`。`...
2. **XML解析**:DOM4J支持多种解析方式,包括SAX(Simple API for XML)和DOM。SAX是基于事件的解析,适用于处理大文件;DOM则将整个XML文档加载到内存,适合小规模或内存允许的情况。DOM4J还提供了StAX(Streaming...
dom4j解析xml字符串实例