关于xml学习(三)—— DOM4J解析

前端之家收集整理的这篇文章主要介绍了关于xml学习(三)—— DOM4J解析前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

@H_502_2@

Dom4j 是一个简单、灵活的开放源代码的库。@H_502_2@ Dom4j 是由早期开发 JDOM 的人分离出来而后独立开发的。与 JDOM 不同的是, dom4j 使用接口和抽象基类,虽然 Dom4j API 相对要复杂一些,但它提供了比 JDOM 更好的灵活性。
使用 Dom4j 开发,需下载 dom4j 相应的 jar 文件

@H_502_2@

Document对象:@H_502_2@

DOM4j 中,获得 Document 对象的方式有三种:@H_502_2@ 1. 读取 XML 文件 , 获得 document 对象 @H_502_2@

SAXReader reader = newSAXReader();@H_502_2@ Document document = reader.read(new File("input.xml"));@H_502_2@

2.解析XML形式的文本,得到document对象

String text = "<members></members>";@H_502_2@ Document document =DocumentHelper.parseText(text);

3.主动创建document对象.

Documentdocument = DocumentHelper.createDocument();@H_502_2@ //创建根节点

Element root = document.addElement("members");

实例:

@H_502_2@

@H_502_2@

节点对象:@H_502_2@

1. 获取文档的根节点 .

Element root =document.getRootElement();

2. 取得某个节点的子节点 .

Elementelement=node.element(“书名");

3. 取得节点的文字

String text=node.getText();

4. 取得某节点下所有名为“ member” 的子节点,并进行遍历 @H_502_2@ List nodes = rootElm.elements("member");@H_502_2@ @H_502_2@ for (Iterator it =nodes.iterator();it.hasNext();) {@H_502_2@ Element elm =(Element) it.next();@H_502_2@ // dosomething@H_502_2@ }
5. 对某节点下的所有子节点进行遍历 .@H_502_2@ for(Iterator it=root.elementIterator();it.hasNext();){@H_502_2@ Element element = (Element)it.next();@H_502_2@ //do something@H_502_2@ }@H_502_2@ 6.在某节点下添加子节点.@H_502_2@ Element ageElm =newMemberElm.addElement("age");
7. 设置节点文字 @H_502_2@ element.setText ("29");
8. 删除某节点 @H_502_2@ // childElm 是待删除的节点 , parentElm 是其父节点

parentElm.remove(childElm);//从父节点删掉子节点,而不是从子节点删掉父节点@H_502_2@

9. 添加一个 CDATA 节点 @H_502_2@ Element contentElm = infoElm.addElement ("content");@H_502_2@ contentElm.addCDATA ( diary.getContent ());
@H_502_2@

节点对象属性:@H_502_2@

1. 取得某节点下的某属性@H_502_2@ Element root=document.getRootElement();@H_502_2@ //属性name

Attribute attribute=root.attribute("size");@H_502_2@

2. 取得属性文字@H_502_2@ String text=attribute.getText();
3. 删除属性@H_502_2@ Attribute attribute = root.attribute ("size");@H_502_2@ root.remove (attribute);
3. 遍历某节点的所有属性@H_502_2@ Element root=document.getRootElement();@H_502_2@ for(Iterator it=root.attributeIterator();it.hasNext();){@H_502_2@ Attribute attribute =(Attribute)it.next();@H_502_2@ String text=attribute.getText();@H_502_2@ System.out.println(text);@H_502_2@ }
4. 设置某节点的属性文字 .@H_502_2@ newMemberElm.addAttribute ("name"," sitinspring ");
5. 设置属性文字@H_502_2@ Attribute attribute = root.attribute ("name");@H_502_2@ attribute.setText("sitinspring");

@H_502_2@

将文档写入XML文件

1. 文档中全为英文 , 不设置编码 , 直接写入的形式 .@H_502_2@ XMLWriter writer = new XMLWriter (new FileWriter ("output.xml"));@H_502_2@ writer.write (document);@H_502_2@ writer.close ();
2. 文档中含有中文 , 设置编码格式写入的形式 .@H_502_2@ OutputFormat format = OutputFormat.createPrettyPrint();@H_502_2@ // 指定XML编码

format.setEncoding("GBK");@H_502_2@ XMLWriterwriter = newXMLWriter(newFileWriter("output.xml"),format);@H_502_2@ writer.write(document);@H_502_2@ writer.close();

@H_502_2@

Dom4j在指定位置插入节点:

1. 得到插入位置的节点列表( list
2. 调用 list.add ( index,elemnent ) ,由 index 决定 element 的插入位置。
Element 元素可以通过 DocumentHelper 对象得到。@H_502_2@ 示例代码

Element aaa =DocumentHelper.createElement("aaa");

aaa.setText("aaa");

List list =root.element("").elements();

list.add(1,aaa);

//更新document

@H_502_2@

字符串与XML的转换:@H_502_2@

1. 将字符串转化为 XML @H_502_2@ String text = "<members> <member>sitinspring</member></members>";@H_502_2@

Document document =DocumentHelper.parseText(text);

2. 将文档或节点的 XML 转化为字符串 .@H_502_2@

SAXReader reader = newSAXReader();@H_502_2@ Document document =reader.read(newFile("input.xml"));@H_502_2@ Element root=document.getRootElement();@H_502_2@ String docXmlText=document.asXML();//把文档的XML转化为字符串

String rootXmlText=root.asXML();//把根节点转化为字符串@H_502_2@ Element memberElm=root.element("member");@H_502_2@ String memberXmlText=memberElm.asXML();//把所有member子节点转化为字符串

XPath:

XPath可用来在XML文档中对元素和属性进行遍历,简化了Dom4j查找节点的过程

注意:使用 XPath 必须导入 jaxen-1.1-beta-6.jar ,否则出现 : NoClassDefFoundError : org/ jaxen / JaxenException
@H_502_2@

@H_502_2@

查询节点:@H_502_2@

获取所有符合条件的节点
selectNodes (String xpathExpression ) :返回 List 集合
获取符合条件的单个节点
selectSingleNode (String xpathExpression ) 返回一个 Node 对象。 如果符合条件的节点有多个,那么返回第一个
设置命名空间
reader.getDocumentFactory () . setXPathNamespaceURIs ( Map)
key :别名(与 schema 中可以不同,默认也需要起名)
value :命名空间的 URL
rootElement.elementByID (“b001”);XML 文档中 ID 属性必须大写
@H_502_2@

实例:

XPathTest.java:

<span style="font-size:14px;">package com.example.dom4j;

import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;

public class XPathTest {
	public static void main(String[] args) throws Exception {
		// 获取解析流
		SAXReader reader = new SAXReader();
		// 解析xml文件
		Document document = reader.read("Book.xml");
		// 查询id为b002的元素
		Node node = document.selectSingleNode("//book[@id='b002']");
		System.out.println(node);
	}
}
</span>
@H_502_2@ dom4jTest.java:
<span style="font-size:14px;">package com.example.dom4j;

import java.util.ArrayList;
import java.util.List;

import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;

import com.example.domain.Book;

public class dom4jTest {
	public static void main(String[] args) throws Exception {
		// 需要list存放所有的book对象
		List allBook = new ArrayList();

		// 获取解析流
		SAXReader reader = new SAXReader();
		// 解析xml文件
		Document document = reader.read("book.xml");
		// 获取根元素
		Element rootElement = document.getRootElement();
		// 获取所有的书籍
		List bookList = rootElement.elements();
		for (int e = 0; e < bookList.size(); e++) {
			Book book = new Book();
			// 获取每一本书
			Element bookElement = (Element) bookList.get(e);
			String id = bookElement.attributeValue("id");
			book.setId(id);
			// 获取每本书的所有元素:title和price
			List childList = bookElement.elements();
			for (int i = 0; i < childList.size(); i++) {
				// 获得每一个子元素
				Element child = (Element) childList.get(i);
				// 获取子元素的文本内容
				String content = child.getText();
				// 获取title
				if ("title".equals(child.getName())) {
					book.setTitle(content);
				}
				// 获取price
				if ("price".equals(child.getName())) {
					book.setPrice(content);
				}
			}
			allBook.add(book);
		}
		System.out.println(allBook);
	}
}
</span>
@H_502_2@ CURDTest.java:
<span style="font-size:14px;">package com.example.dom4j;

import java.io.FileOutputStream;

import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;

public class CURDTest {
	public static void main(String[] args) throws Exception {
		// 获取解析流
		SAXReader reader = new SAXReader();
		// 解析xml文件
		Document document = reader.read("Book.xml");
		
		//…………

		// 将document另存
		// 创建文件保存位置
		FileOutputStream fos = new FileOutputStream("Book.dom4j.xml");
		XMLWriter writer = new XMLWriter(fos);
		writer.write(document);
		writer.close();
	}

	private static void add() throws Exception {
		// 获取解析流
		SAXReader reader = new SAXReader();
		// 解析xml文件
		Document document = reader.read("Book.xml");

		// 添加:
		// 获得根元素
		Element rootElement = document.getRootElement();
		// 创建book元素
		Element newBook = DocumentHelper.createElement("book");
		// 创建属性
		Attribute newBookAttribute = DocumentHelper.createAttribute(newBook,"id","b004");
		// 将属性添加到newBook中
		newBook.add(newBookAttribute);
		// 创建newBook中的元素
		Element titleElement = DocumentHelper.createElement("title");
		titleElement.setText("C和指针");
		// 将元素添加进newBook中
		newBook.add(titleElement);
		// 将newBook添加如root中
		rootElement.add(newBook);

		// 将document另存
		// 创建文件保存位置
		FileOutputStream fos = new FileOutputStream("Book.dom4j.xml");
		XMLWriter writer = new XMLWriter(fos);
		writer.write(document);
		writer.close();
	}

	private static void delete(Document document) throws Exception {
		// 删除:b001
		Node bookNode = document.selectSingleNode("//book[@id='b001']");
		Node parent = bookNode.getParent();
		Element parentElement = (Element) parent;
		parentElement.remove(bookNode);

		// 将document另存
		// 创建文件保存位置
		FileOutputStream fos = new FileOutputStream("Book.dom4j.xml");
		XMLWriter writer = new XMLWriter(fos);
		writer.write(document);
		writer.close();
	}

	private static void update(Document document) throws Exception {
		// 修改:b002 title 编程思想
		Node bookNode = document.selectSingleNode("//book[@id='b002']");
		Element bookElement = (Element) bookNode;
		Element titleElement = bookElement.element("title");
		// System.out.println(titleElement.getText());
		titleElement.setText("编程思想");

		// 将document另存
		// 创建文件保存位置
		FileOutputStream fos = new FileOutputStream("Book.dom4j.xml");
		XMLWriter writer = new XMLWriter(fos);
		writer.write(document);
		writer.close();
	}

	private static void sava(Document document) throws Exception {
		//保存
		// 将document另存
		// 创建文件保存位置
		FileOutputStream fos = new FileOutputStream("Book.dom4j.xml");
		XMLWriter writer = new XMLWriter(fos);
		writer.write(document);
		writer.close();
	}
}
</span>

猜你在找的XML相关文章