使用dom4j解析XML详解编程语言

一、简介
       dom4j是一个Java的XML API,类似于jdom,用来读写XML文件的。dom4j是一个非常非常优秀的Java XML API,具有性能优异、功能强大和极端易用使用的特点,同时它也是一个开放源代码的软件,可以在SourceForge上找到它。
使用Dom4j开发,需下载dom4j相应的jar文件
       1、官网下载:http://www.dom4j.org/dom4j-1.6.1/
       2、dom4j是sourceforge.net上的一个开源项目,因此可以到http://sourceforge.net/projects/dom4j下载其最新版.
二、实例(解析xml)
      1、dom4j.xml文件内容,如下:

<?xml version="1.0" encoding="UTF-8"?> 
<books>  
	<xiyouji id="x001">  
		<author>吴承恩</author>   
		<times>明朝</times>  
	</xiyouji>   
	<hongloumeng id="x002">  
		<author>曹雪芹</author>   
	</hongloumeng>  
</books>

     2、测试类

package com.test; 
 
import java.io.File; 
import java.io.FileOutputStream; 
import java.io.OutputStreamWriter; 
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.OutputFormat; 
import org.dom4j.io.SAXReader; 
import org.dom4j.io.XMLWriter; 
 
public class TestDOM4JForXML { 
	public static void main(String[] args) throws Exception { 
		TestDOM4JForXML.readXML("dom4j.xml"); 
		TestDOM4JForXML.updateXML("dom4j.xml"); 
	} 
 
	/** 
	 * 获取document对象 
	 */ 
	public static Document getDocument(String fileName) { 
		SAXReader saxReader = new SAXReader(); 
		Document document = null; 
		try { 
			document = saxReader.read(new File(fileName));// 通过read方法读取一个文件,转换成Document对象 
		} catch (DocumentException e) { 
			e.printStackTrace(); 
		} 
		return document; 
	} 
 
	/** 
	 * 读取xml文件的内容 
	 */ 
	public static void readXML(String fileName) throws Exception { 
		Document document = getDocument(fileName); 
		Element node = document.getRootElement(); 			// 获取根节点元素对象 
		listNodes(node); 
	} 
	 
	public static void listNodes(Element node) { 
		System.out.println("节点名称:" + node.getName());	//获取当前节点的名称 
		List<Attribute> list = node.attributes(); 			// 获取当前节点的所有属性节点 
		for (Attribute attr : list) { 						// 遍历属性节点 
			System.out.println(attr.getText() + "-----" + attr.getName() + "---" + attr.getValue()); 
		} 
		if (!(node.getTextTrim().equals(""))) { 
			System.out.println("文本内容:" + node.getText()); 
		} 
		Iterator<Element> it = node.elementIterator();		// 当前节点下面子节点迭代器 
		while (it.hasNext()) { 
			Element e = it.next();							// 获取某个子节点对象 
			listNodes(e);									// 对子节点进行遍历 
		} 
	} 
	 
	/** 
	 * 修改xml文件的内容 
	 */ 
	public static void updateXML(String fileName) throws Exception { 
		Document document = getDocument(fileName); 
		Element node = document.getRootElement(); 			// 获取根节点元素对象 
        Element element = node.element("hongloumeng");  	// 获取books元素节点中,子节点名称为hongloumeng元素节点。   
        Attribute attr = element.attribute("id");  			// 获取element的id属性节点对象   
        element.remove(attr);  								// 删除属性 
        element.addAttribute("name", "作者");  				// 添加新的属性   
         
        Element newElement = element.addElement("朝代");  	// 在hongloumeng元素节点中添加朝代元素的节点   
        newElement.setText("清朝");  						// 获取element中的作者元素节点对象   
        Element author = element.element("作者");   
        boolean flag = element.remove(author);   			// 删除元素节点  (返回true代码删除成功,否则失败  ) 
        Element descElement = element.addElement("简介"); 
        descElement.addCDATA("红楼梦,是一部爱情小说。");  		//添加CDATA区域   
        writer(document);   
	} 
 
	/**  
     * 把document对象写入新的文件  
     */   
    public static void writer(Document document) throws Exception {   
        // OutputFormat format = OutputFormat.createCompactFormat();  	// 紧凑的格式   
        OutputFormat format = OutputFormat.createPrettyPrint();  		// 排版缩进的格式   
        format.setEncoding("UTF-8");  							 		// 设置编码   
        // 创建XMLWriter对象,指定了写出文件及编码格式   
        // XMLWriter writer = new XMLWriter(new FileWriter(new File("dom4j.xml")),format);   
        XMLWriter writer = new XMLWriter(new OutputStreamWriter( new FileOutputStream(new File("dom4j.xml")), "UTF-8"), format);   
        writer.write(document);   		// 写入   
        writer.flush();  				// 立即写入   
        writer.close();  				// 关闭操作   
    }   
	 
}

三、实例(字符串与XML互转换

package com.test; 
 
import java.io.File; 
import java.io.FileOutputStream; 
import java.io.FileWriter; 
import java.io.OutputStreamWriter; 
 
import org.dom4j.Document; 
import org.dom4j.DocumentException; 
import org.dom4j.DocumentHelper; 
import org.dom4j.Element; 
import org.dom4j.io.OutputFormat; 
import org.dom4j.io.SAXReader; 
import org.dom4j.io.XMLWriter; 
 
public class TestParseXML { 
	public static void main(String[] args) throws Exception { 
		TestParseXML.parseXML(); 
		TestParseXML.updateXML(); 
		TestParseXML.readXML(); 
	} 
	 
	/** 
	 * 获取document对象 
	 */ 
	public static Document getDocument(String fileName) { 
		SAXReader saxReader = new SAXReader(); 
		Document document = null; 
		try { 
			document = saxReader.read(new File(fileName));// 通过read方法读取一个文件,转换成Document对象 
		} catch (DocumentException e) { 
			e.printStackTrace(); 
		} 
		return document; 
	} 
	 
 
    /**  
     * 把一个文本字符串转换Document对象  
     */   
    public static void parseXML() throws Exception {   
        String text = "<csdn><java>Java班</java><net>Net班</net></csdn>";   
        Document document = DocumentHelper.parseText(text);   
        writer(document);   
    }   
	 
	/**  
     * 创建一个document对象 往document对象中添加节点元素 转存为xml文件  
     */   
    public static void updateXML() throws Exception {   
        Document document = DocumentHelper.createDocument();	// 创建根节点   
        Element root = document.addElement("csdn");   
        Element java = root.addElement("java");   
        java.setText("java班");   
        Element ios = root.addElement("ios");   
        ios.setText("ios班");   
        writer(document);   
    }   
	 
	public static void readXML() { 
		Document document = getDocument("csdn.xml");   
        Element root = document.getRootElement();   
        String docXmlText = document.asXML();   	// 把文档转换字符串 
        System.out.println(docXmlText);   
        System.out.println("---------------------------");   
         
        String rootXmlText = root.asXML();  		// books元素标签根转换的内容   
        System.out.println(rootXmlText);   
        System.out.println("--------------------------");   
         
        Element e = root.element("java");  	// 获取hongloumeng元素标 内的内容   
        System.out.println(e.asXML());   
	} 
     
   
    /**  
     * 把document对象写入新的文件  
     */   
    public static void writer(Document document) throws Exception {   
        // OutputFormat format = OutputFormat.createCompactFormat();  	// 紧凑的格式   
        OutputFormat format = OutputFormat.createPrettyPrint();  		// 排版缩进的格式   
        format.setEncoding("UTF-8");  							 		// 设置编码   
        // 创建XMLWriter对象,指定了写出文件及编码格式   
        // XMLWriter writer = new XMLWriter(new FileWriter(new File("csdn.xml")),format);   
        XMLWriter writer = new XMLWriter(new OutputStreamWriter( new FileOutputStream(new File("csdn.xml")), "UTF-8"), format);   
        writer.write(document);   		// 写入   
        writer.flush();  				// 立即写入   
        writer.close();  				// 关闭操作   
    }   
}

原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/16353.html

(0)
上一篇 2021年7月19日
下一篇 2021年7月19日

相关推荐

发表回复

登录后才能评论