以下示例比较简单,仅供初学者参考。
示例引用包:dom4j-1.6.1
读取xml文件:
import java.io.ByteArrayInputStream;
import java.io.File;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.Iterator;
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.ProcessingInstruction;
import org.dom4j.VisitorSupport;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
public class XmlReaderDom4j {
public static void main(String[] args){
//readGB2312();
readUTF8();
}
public static void readGB2312(){
SAXReader reader = new SAXReader();
File file = new File("src/students.xml");
try {
Document doc = reader.read(file);
doc.accept(new MyVistor());
} catch (DocumentException e) {
e.printStackTrace();
}
}
public static void readUTF8(){
try{
SAXReader reader = new SAXReader();
OutputFormat format = OutputFormat.createPrettyPrint();
format.setEncoding("UTF-8"); //设置XML文件的编码格式
File file = new File("src/author.xml");
if(file.exists()){
Document document = reader.read(file); // 读取XML文件
Element root = document.getRootElement(); // 得到根节点
for(Iterator i = root.elementIterator(); i.hasNext();){
Element e = (Element) i.next();
System.out.println(e.getName());
System.out.println(e.getPath());
System.out.println(e.getText());
System.out.println(e.getStringValue());
for(Iterator j = e.attributeIterator();j.hasNext();){
Attribute attribute = (Attribute) j.next();
System.out.println(attribute.getStringValue());
}
}
}else{
System.out.println("文件没找到");
}
}catch(Exception e){
e.printStackTrace();
}
}
/**
* 获取Dom4j的Document对象
* @param data
* @param charset
* @return
*/
public static Document getDocument(String data, String charset) {
SAXReader reader = new SAXReader();
Document document = null;
InputStreamReader utfreader = null;
InputStream in = null;
try {
in = new ByteArrayInputStream(data.getBytes());
utfreader = new InputStreamReader(in, charset);
document = reader.read(utfreader);
}catch (Exception e) {
e.printStackTrace();
}finally {
try {
in.close();
}
catch (IOException e) {
e.printStackTrace();
}
}
return document;
}
/**
* 内部类
* @author Administrator
*
*/
public static class MyVistor extends VisitorSupport {
public void visit(Attribute node) {
System.out.println("** Attibute:" + node.getName() + "="
+ node.getValue());
}
public void visit(Element node) {
if (node.isTextOnly()) {
System.out.println("** Element:" + node.getName() + "="
+ node.getText());
}else{
System.out.println("--------" + node.getName() + "-------");
}
}
@Override
public void visit(ProcessingInstruction node) {
System.out.println("** PI:"+node.getTarget()+" "+node.getText());
}
}
}
author.xml
<?xml version="1.0" encoding="UTF-8"?>
<root>
<author name="詹姆斯" location="UK">小皇帝</author>
<author name="科比" location="US">Bob McWrirter</author>
</root>
生成XML文件:
import java.io.FileWriter;
import java.io.IOException;
import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.XMLWriter;
public class XmlWriterDom4j {
public static void main(String[] args) {
try {
XMLWriter writer = new XMLWriter(new FileWriter("src/author.xml"));
Document doc = createDoc();
writer.write(doc);
writer.close();
// Pretty print the document to System.out
// 設置了打印的格式,将读出到控制台的格式进行美化
OutputFormat format = OutputFormat.createPrettyPrint();
writer = new XMLWriter(System.out, format);
writer.write(doc);
} catch (IOException e) {
e.printStackTrace();
}
}
public static Document createDoc() {
Document doc = DocumentHelper.createDocument();
Element root = doc.addElement("root");
Element author1 = root.addElement("author")
.addAttribute("name","James")
.addAttribute("location", "UK")
.addText("Jame Strachan");
Element author2 = root.addElement("author")
.addAttribute("name", "Bob")
.addAttribute("location", "US")
.addText("Bob McWrirter");
return doc;
}
}
分享到:
相关推荐
Dom4j解析XML文档.doc Dom4j解析XML文档.doc Dom4j解析XML文档.doc Dom4j解析XML文档.doc
xml文件解析之dom4j的jar
1、xml文档解析 2、 dom4j解析xml 3、实现xml文件解析 xml字符串解析 xml MAP键值对解析 4、实现xml写入与生成文件
dom4j解析xml文件代码示例 dom4j解析xml文件代码示例 dom4j解析xml文件代码示例
基于dom4j的读写xml文件的工具包。封装了dom4j操作xml文档的常和方法。 支持两种读写方法。1:针对小文件的读取整个文档,2:针对大文件的,逐行读取。读到几百M文件毫无压力。
dom4j是一种解析XML文档的开放源代码XML框架。本文介绍如何使用包含在dom4j中的解析器创建并修改XML文档。dom4j API包含一个解析XML文档的工具。本文中将使用这个解析器创建一个示例XML文档,然后使用同一个解析器...
通过dom4j解析xml,修改xml,自动生成xml文件。使用dom4j模拟解析web.xml配置文件,同时考虑到一个url-pattern和多个url-pattern的情况。
很详细的文档 可以借鉴下 希望对你有帮助
此方法解析xml时,不受xml层级的限制。文件中包含了说明文档,java类,以及所使用到的*.jar。并对代码做了注释让你一目了然……
Dom4j解析xml与配置文件的小例子,简单的Dom4j的小应用。
dom4j解析xml文件的压缩包,完整版。对jdom进行了封装。包含源码,jar包以及所需的全部内容。
dom,dom4j,sax解析xml 文件经典实例,内置详细注解
dom4j是一个Java的XML API,类似于jdom,用来读写XML文件的。dom4j是一个非常非常优秀的Java XML API,具有性能优异、功能强大和极端易用使用的特点,同时它也是一个开放源代码的软件,可以在SourceForge上找到它。...
dom4j解析XML文件格式dom4j解析XML文件格式dom4j解析XML文件格式
Dom4j解析和生成XML文档 Dom4j解析和生成XML文档 Dom4j解析和生成XML文档 Dom4j解析和生成XML文档 Dom4j解析和生成XML文档
使用dom4j 和本地dom 解析xml 文件
有四种方法 DOM DOM4j JDOM SAX 和相对路径的写法 ,代码是有注释的,通用型的……应该对大家有帮助
一个很好的用来解析XML文件的解析包 DOM4J是dom4j.org出品的一个开源XML解析包,它的网站中这样定义: Dom4j is an easy to use, open source library for working with XML, XPath and XSLT on the Java platform ...
Java使用sax、dom、dom4j解析xml文档的代码,包含dom4j的jar包。
分别使用DOM和DOM4j解析XML文件,因为目前使用最广泛的是DOM4j所以只写了用DOM4j对XML进行增删改查。