`
xiangkun
  • 浏览: 102602 次
  • 性别: Icon_minigender_1
  • 来自: 马尔代夫
社区版块
存档分类
最新评论

DOM4j解析xml

阅读更多
--------------------------------------------------
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解析XML详解 #### 一、DOM4J简介与特性 DOM4J是一个由dom4j.org开发的开源XML解析包,专为Java平台设计,它不仅支持DOM、SAX和JAXP标准,还巧妙地融入了Java集合框架,使其成为Java开发者在处理XML数据时...

    使用 dom4j 解析 XML

    使用 dom4j 解析 XML dom4j 解析 XML dom4j解析xml

    DOM4J 解析XML

    **DOM4J解析XML** DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了灵活、高效且功能丰富的API,使得XML的读取、创建、修改和查询变得简单易行。DOM4J的主要特点包括对XPath的支持、事件驱动的解析、以及与...

    dom4j解析xml

    ### DOM4J解析XML知识点详解 #### 一、DOM4J简介 DOM4J是一个Java库,用于处理XML文档。它的设计目标是为了提供一个简单、易于使用的API来处理XML文件,同时保持性能上的优势。与Java标准库中的DOM实现相比,DOM4J...

    java dom4j解析xml

    Java DOM4J解析XML是一种常见的处理XML文档的技术,它提供了灵活且高效的API,使得开发者能够方便地读取、写入、修改以及操作XML文件。DOM4J是Java中一个非常强大的XML处理库,它结合了DOM、SAX和JDOM的优点,同时也...

    dom4j解析xml文件(增删改查)

    在“dom4j解析xml文件(增删改查)”这个主题中,我们将深入探讨如何使用DOM4J来实现XML文档的四种基本操作:增加元素、删除元素、更新元素内容以及查询元素。 首先,让我们了解DOM4J的基本用法。在解析XML文件时,...

    dom4j解析xml实例

    **DOM4J解析XML实例详解** 在Java编程中,处理XML文档是一项常见的任务。DOM4J是一个非常流行的、强大的Java XML API,它提供了灵活且高效的方式来解析、创建、修改XML文档。本文将深入探讨如何使用DOM4J进行XML...

    dom4j 解析xml实例

    在这个实例中,我们将深入探讨如何使用DOM4J解析XML文件,并通过`Dom4jTest1.java`这个示例程序来理解其工作原理。 首先,我们需要了解XML(Extensible Markup Language)是一种标记语言,常用于存储和传输数据。...

    dom4j解析XML

    本人自己研究的解析方法,主要用dom4j解析XML文件,进而获取里面的信息

    dom4j解析xml,利用反射机制

    通过这种方式,我们可以利用DOM4J解析XML文件,同时借助Java反射机制将解析结果动态地映射到自定义的Java类中。这在处理XML数据时提供了很大的灵活性,尤其在需要将XML数据与业务对象关联时,反射机制显得尤为重要。

    dom4j解析xml文件代码示例

    在本示例中,我们将深入探讨如何使用DOM4J解析XML文件,以`CacheInit.java`作为我们的核心代码示例,并参考`emailTemplateConfig.xml`作为实际操作的对象。 首先,让我们了解XML(eXtensible Markup Language)。...

    java dom4j 解析xml的例子,可用

    1. **DOM4J解析XML**:DOM4J通过创建一个可操作的树形结构来表示XML文档,这棵树称为文档对象模型。解析XML时,DOM4J首先读取XML文件并构建一个节点结构,然后你可以通过API遍历和修改这个结构。例如,你可以通过...

    使用dom4j解析XML

    【使用dom4j解析XML】 dom4j是一个强大的开源XML框架,它提供了处理XML文档的各种功能,包括解析、创建、修改等。相比W3C DOM API,dom4j的优势在于其内置的XPath支持,允许更方便地定位和操作XML文档中的节点。 *...

    dom4j 解析写入xml

    1、xml文档解析 2、 dom4j解析xml 3、实现xml文件解析 xml字符串解析 xml MAP键值对解析 4、实现xml写入与生成文件

    dom4j解析XML所需要的jar包

    为了在Java项目中使用DOM4J解析XML,你需要将这两个jar文件(dom4j-1.6.1和jaxen-1.1-beta-7.jar)添加到你的类路径(classpath)中。这可以通过在IDE中配置构建路径,或者在命令行中指定 `-cp` 参数来完成。一旦...

    dom4j解析xml,连接oracle数据库

    在本实例中,我们将深入探讨如何使用DOM4J解析XML,并利用这些数据连接Oracle数据库进行数据操作。 首先,让我们了解DOM4J的基本用法。DOM4J的主要类包括`Document`、`Element`、`Attribute`和`Namespace`。`...

    dom4j解析XML所需jar包

    2. **XML解析**:DOM4J支持多种解析方式,包括SAX(Simple API for XML)和DOM。SAX是基于事件的解析,适用于处理大文件;DOM则将整个XML文档加载到内存,适合小规模或内存允许的情况。DOM4J还提供了StAX(Streaming...

    dom4j解析xml字符串实例

    dom4j解析xml字符串实例

Global site tag (gtag.js) - Google Analytics