当前位置:首页 > 开发 > 编程语言 > XML > 正文

DOM4J解析XML

发表于: 2014-04-02   作者:周仁明   来源:转载   浏览:
摘要: 一:要导入的包 dom4j-1.6.1.jar jaxen-1.1-bata-6.jar 二:源码 package com;   import java.io.File; import java.io.FileWriter; import java.io.IOException; import java.util.List;   import
一:要导入的包
dom4j-1.6.1.jar
jaxen-1.1-bata-6.jar
二:源码
package com;
 
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.util.List;
 
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;
/**
* 该类主要用于测试dom4j创建xml文件和解析xml文件
* 创建xml文件: 1.通过新建document创建,如write1
* 2.解析定义好的xml字符串,如write2
* 解析xml文件:读取xml文件,通过遍历节点找到节点的属性和属性值。
* @author zhourm
*
*/
public class TestReadWrite {
public static void main(String[] args) {
TestReadWrite test = new TestReadWrite();
String roadStr = "D:/createXMLtest.xml";
//test.write1(roadStr);
test.write2(roadStr);
test.read(roadStr);
}
public void write1(String roadStr){
System.out.println("写xml方法一");
 
Document document = DocumentHelper.createDocument();
Element documentElement = document.addElement("document");
documentElement.addAttribute("action", "UP");
documentElement.addAttribute("count", "2");
documentElement.addElement("metaid").addAttribute("id", "ISBN7-200-04263-3").setText("test1");
documentElement.addElement("metaid").addAttribute("id", "u.meta2010122824-07763-1/TS·250qesu100").setText("test2");
try{
XMLWriter output = new XMLWriter(
new FileWriter( new File(roadStr) ));
output.write( document );
output.close();
}
catch(IOException e){System.out.println(e.getMessage());}
}
public void write2(String roadStr){
System.out.println("写xml方法二");
 
String xml =
"<?xml version=\"1.0\" encoding=\"UTF-8\" ?> "+
"<document action=\"UP\" count=\"2\">"+
"<metaid id=\"ISBN7-200-04263-3\" />"+
"<metaid id=\"u.meta2010122824-07763-1/TS·250qesu100\" />"+
"</document>";
 
Document document;
try {
document = DocumentHelper.parseText(xml);
try{
XMLWriter output = new XMLWriter(
new FileWriter( new File(roadStr) ));
output.write( document );
output.close();
}
catch(IOException e){System.out.println(e.getMessage());}
} catch (DocumentException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
}
public void read(String roadStr) {
//根据路径读取xml数据
File inputXml = new File(roadStr);
SAXReader saxReader = new SAXReader();
Document srcDoc;
// 解析元数据
List nodes ;
try {
srcDoc = saxReader.read(inputXml);
nodes = srcDoc.selectNodes("//metaid");
//若解析失败
if (null == nodes || nodes.isEmpty()) {
//若解析到的id为空则提示错误信息
System.out.println("解析错误");
}else{
//若解析成功
int i = 0;
for (Object obj : nodes) {
i ++;
Element metaIdElement = (Element) obj;
//获取节点的id属性值
String mataId = metaIdElement.attributeValue("id");
System.out.println("节点的属性ID取值为:"+mataId);
String mataValue = metaIdElement.getTextTrim();
System.out.println("节点的值为:"+mataValue);
}
System.out.println("获取到的节点个数为:"+i);
}
} catch (DocumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}

DOM4J解析XML

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

编辑推荐
dom4j 是一种解析 XML 文档的开放源代码 XML 框架。本文介绍如何使用包含在 dom4j 中的解析器创建并
dom4j是一个Java的XML API,类似于jdom,用来读写XML文件的。dom4j是一个非常非常优秀的Java XML AP
dom4j是一个Java的XML API,类似于jdom,用来读写XML文件的。dom4j是一个非常非常优秀的Java XML AP
dom4j是一个Java的XML API,类似于jdom,用来读写XML文件的。dom4j是一个非常非常优秀的Java XML AP
下面我们看一下dom4j解析XML是怎么解析的直接上代码: XML: <?xml version="1.0" encoding="GB2
dom4j是一个Java的XML API,类似于jdom,用来读写XML文件的。dom4j是一个非常非常优秀的Java XML AP
1、Dom4j概述 dom4j is an easy to use, open source library for working with XML, XPath and XSL
DOM4J 与利用DOM、SAX、JAXP机制来解析xml相比,DOM4J 表现更优秀,具有性能优异、功能强大和极端易
今天,碰到了这样的问题:自己写了一个config.xml这样的配置文件, 路径:D:\programming software\
Dom4j遍历解析XML测试 近来老和XML打交道,不深挖不行了。。 这是一个Dom4j解析XML的例子,为做复杂
版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号