Java---XML的解析(2)-DOM4J解析/Xpath

谙忆 2021-01-21 12:55:09
java 解析 dom4j xml java---xml


Dom4j: Dom SUN dom在加载时,将所有元素全部加载内存 DOM4j - 第三方。

Dom4j是一个开源、灵活的XML API。 目前很多开源框架如struts,hibernate都使用dom4j做为解析其xml的工具。 支持文档的读写功能和Xpath快速查询操作。

这个需要我们自己把它的包导入myeclipse中的。 准备DOM4j: 包:dom4j.x.jar 包结构: org.dom4j 类 org.dom4j.io.SAXReader – xml文档解析器 org.dom4j.Document、Element – 文档对像 需要知道的 Element的一些方法 Element.element(“name”) –此元素下的第一个name元素。 Element.elementIterator(“name”) – 此元素下的所有name元素。返回Iterator Element.getText() – 返回元素包含的文本。 Element.getAttribute(“name”) – 返回名称为name的属性。 Element.addElement(“name”); - 添加一个name元素,同时返回name元素本身。 org.dom4j.io.XMLWriter – 将Document写出的对像。

DOM4J的层次图:

使用UTF-8编码,解决中文乱码:

//声明编码格式
OutputFormat format = OutputFormat.createPrettyPrint();
format.setEncoding("UTF-8");
//保存(XMLWriter默认情况下即是使用UTF-8编码。所以,如果使用OutputStream保存,且正好是UTF-8编码,则不必担心乱码问题)
XMLWriter xml = new XMLWriter(new FileOutputStream("./src/xml/a.xml"),format);
xml.write(doc);

Dom4j-保存节点-处理中文乱码:

在JavaIO中,writer总是本地编码格式处理数据。即GB2312
所有,使用writer写出数据有可能会发生一些问题,如保存不完整,或是乱码:
XMLWriter writer = new XMLWriter(new FileWriter(“a.xml”));
//写出数据
writer.write(doc);
所以,建议在写出数据时,使用OutputStream保存数据。

记住:删除一个节点时,要用它的父节点删除它。

添加或修改属性的方法:addAttribute

Dom4j-从没有到有生成一个新的xml:

//通过DocumentHelper在内存中创建一个Document
Document doc = DocumentHelper.createDocument();
doc.setXMLEncoding(“UTF-8”);//XML的编码格式
//生成一个节点,生成的第一个节点也是根节点,此方法只使用一次
Element root = doc.addElement(“users”);

Xpath

XML PATH Language。
可以实现快速查询。
XPATH包含
XPath 使用路径表达式在 XML 文档中进行导航 。
XPath 包含一个标准函数库
准备Xpath的包:
jaxen.jar
Xpath通过以下方法使用
dom.selectNodes – 返回一个 List对像
dom.selectSingleNode – 返回一个Node对像
//以下选择所有的user节点,处理不带命名空间的安以下原则
List<Element> list = doc.selectNodes("//user");
System.err.println(list.size());
//以下选择所有name节点
list = doc.selectNodes("//name");//或从要开始:/users//name
System.err.println(list.size());
//以下选择所在带有country属性的节点
list = doc.selectNodes("//user[@country]");
System.err.println(list.size());
//选择国家是 EN的节点,可以使用以下方法查询用户登录
//如果country不能重复则可以使用selectSingleNode
//使用双引号或单引号都可以://user
Node node = doc.selectSingleNode("//user[@country=\"EN\"]");
System.err.println(node);
Xpath通过查询子元素的值,区别主要元素:
如:XML文档如下:
<books>
<book id=“A001”>
<name>Oracle编程基础</name>
<price>89.99</price>
</book>
</books>
查询包含Oracle一词的所有book元素。
//book[name=‘Oracle’] //精确查询子元素name的值为Oracle的book元素
//以下是模糊查询
//book[contains(name,’Oracle’)]
//也可以将name元素的值转成小写
//book[contains(fn:lower-case(name),’oracle’]

这个稍微了解一下: Xpath处理带有命名空间的XML文档:

SAXReader sax = new SAXReader();
//声明一个map用于保存命名空间
Map<String,String> uris = new HashMap<String, String>();
//给命名空间取一个别名
uris.put("a", "http://www.itcast.cn");
//设置命名空间后再读取xml文档
sax.getDocumentFactory().setXPathNamespaceURIs(uris);
Document dom = sax.read("./xml2/a.xml");
//然后使用带有命名空间的前缀查询即可。
dom.selectNodes(“//a:book”);
//带有属性的查询同前
dom.selectNodes(//a:book[@id]
//带有元素的查询必须要添加命名空间的前缀
dom.seletNodes(“//a:book[a:name=‘oralce’]”); //查询子元素值为oracle的book元素

SAX,StAX读取速度快。都是JAXP的成员。 StAX-Iterator编程接口和Cursor编程接口。 Dom4j。Dom。都会将所有节点加载加载到内存中。CRUD非常方便。 Dom4j支持XPath.

演示代码:::

package cn.hncu.dom4j;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.FileWriter;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.util.Iterator;
import java.util.List;
import java.util.Scanner;
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;
import org.junit.Test;
public class Dom4jDemo {
@Test
public void readDemo() throws Exception{
//声明SAXReader核心读取(xml)类,并获得dom对象
SAXReader sax = new SAXReader();
Document dom = sax.read("xml5/users.xml");
//获取根节点
Element root = dom.getRootElement();
//获取里面的第一个子元素
Element user = root.element("user");
String id = user.attributeValue("id");
System.out.println(id);
String name = user.element("name").getText();//获取子元素中的文本内容--法1
String age = user.elementText("age");//获取子元素中的文本内容--法2
System.out.println(name+","+age);
}
//显示(遍历)所有用户
@Test
public void readAll() throws Exception{
SAXReader reader = new SAXReader();
Document document = reader.read("xml5/users.xml");
Element root = document.getRootElement();
Iterator<Element> it = root.elementIterator();
while(it.hasNext()){
Element e = it.next();
String id = e.attributeValue("id");
String name = e.elementText("name");
String age = e.element("age").getText();
System.out.println("id:"+id+",name:"+name+",age:"+age);
}
}
//添加一个user元素
@Test
public void addElement() throws Exception{
SAXReader sax= new SAXReader();
Document document = sax.read("xml5/users.xml");
Element root = document.getRootElement();
Element e = root.addElement("user");
e.addAttribute("id", "C003");
Element eName = e.addElement("name");
eName.setText("张三");
Element eAge = e.addElement("age");
eAge.setText("24");
//要把内存中的dom对象写到磁盘中
//法一---功能有限
// FileWriter fw = new FileWriter("xml5/users.xml");//输出到控制台
// document.write(fw);
// fw.close();
//法二---功能更强
OutputFormat format = OutputFormat.createCompactFormat();
format.setEncoding("utf-8");
XMLWriter writer = new XMLWriter(new FileWriter("xml5/users.xml"), format);
//以指定的输出格式,把dom输出到指定的目的地(文件)
writer.write(document);
writer.close();
}
//删除最后一个user元素
@Test
public void delElement() throws Exception{
SAXReader reader = new SAXReader();
Document document = reader.read("xml5/users.xml");
Element root = document.getRootElement();
List<Element> list = root.elements();
Element e = list.get(list.size()-1);
e.getParent().remove(e);
//保存
XMLWriter writer = new XMLWriter(new FileWriter("xml5/users.xml"));
writer.write(document);
writer.close();
}
//从零开始创建一个xml文档
@Test
public void createNewXml() throws IOException, FileNotFoundException{
Document document = DocumentHelper.createDocument();
Element root = document.addElement("hncu");
root.addElement("department").addAttribute("id", "hncu001").addElement("xky").setText("信息科学与工程学院");
//保存
XMLWriter writer = new XMLWriter(new FileOutputStream("xml5/hncu.xml"));
writer.write(document);
writer.close();
}
//xpath的用法
@Test
public void xpathDemo() throws Exception{
SAXReader sax = new SAXReader();
Document dom = sax.read("xml5/contact.xml");
//String xpath = "/*/name";//第一个/表示当前元素
//String xpath="//contact/name";//选择contact下面的name(儿子)
//String xpath="//aaa/preceding::*";//选择<aaa>前面的所有元素
String xpath="//*[@id]";//选择具有id属性的所有元素
Element root = dom.getRootElement();
System.out.println(root.getName());
List<Element> list = root.selectNodes(xpath);
for(Element e:list){
System.out.println(e.getName()+"--"+e.getText());
}
}
//xpath用法
@Test
public void xpathDemo2() throws Exception {
SAXReader sax = new SAXReader();
Document dom = sax.read("xml5/contact.xml");
Scanner sc = new Scanner(System.in);
String name =sc.next();
//name=name.toLowerCase();
String pwd = sc.next();
//String xpath="//user[@name][@pwd]";//选择同时包含name和pwd属性的user元素
//String xpath="//user[@name='Jack'][@pwd='1234']";//选择name='Jack'且pwd='1234'那个user元素
//String xpath="//user[@name='"+name+"'][@pwd='"+pwd+"']";//按照输入的name和ped查找那个user---name区分大小写
String xpath="//user[fn:lower-case(@name)='"+name+"'][@pwd='"+pwd+"']";//按照输入的name和ped查找那个user---name不区分大小写
System.out.println(xpath);
List<Element> list = dom.selectNodes(xpath);
for(Element e:list){
System.out.println(e.getName());
List<Element> eList = e.selectNodes("//contact/name");
for(Element e2:eList){
System.out.println(e2.getText());
}
}
}
}

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

版权声明
本文为[谙忆]所创,转载请带上原文链接,感谢
https://cloud.tencent.com/developer/article/1777190

  1. 【计算机网络 12(1),尚学堂马士兵Java视频教程
  2. 【程序猿历程,史上最全的Java面试题集锦在这里
  3. 【程序猿历程(1),Javaweb视频教程百度云
  4. Notes on MySQL 45 lectures (1-7)
  5. [computer network 12 (1), Shang Xuetang Ma soldier java video tutorial
  6. The most complete collection of Java interview questions in history is here
  7. [process of program ape (1), JavaWeb video tutorial, baidu cloud
  8. Notes on MySQL 45 lectures (1-7)
  9. 精进 Spring Boot 03:Spring Boot 的配置文件和配置管理,以及用三种方式读取配置文件
  10. Refined spring boot 03: spring boot configuration files and configuration management, and reading configuration files in three ways
  11. 精进 Spring Boot 03:Spring Boot 的配置文件和配置管理,以及用三种方式读取配置文件
  12. Refined spring boot 03: spring boot configuration files and configuration management, and reading configuration files in three ways
  13. 【递归,Java传智播客笔记
  14. [recursion, Java intelligence podcast notes
  15. [adhere to painting for 386 days] the beginning of spring of 24 solar terms
  16. K8S系列第八篇(Service、EndPoints以及高可用kubeadm部署)
  17. K8s Series Part 8 (service, endpoints and high availability kubeadm deployment)
  18. 【重识 HTML (3),350道Java面试真题分享
  19. 【重识 HTML (2),Java并发编程必会的多线程你竟然还不会
  20. 【重识 HTML (1),二本Java小菜鸟4面字节跳动被秒成渣渣
  21. [re recognize HTML (3) and share 350 real Java interview questions
  22. [re recognize HTML (2). Multithreading is a must for Java Concurrent Programming. How dare you not
  23. [re recognize HTML (1), two Java rookies' 4-sided bytes beat and become slag in seconds
  24. 造轮子系列之RPC 1:如何从零开始开发RPC框架
  25. RPC 1: how to develop RPC framework from scratch
  26. 造轮子系列之RPC 1:如何从零开始开发RPC框架
  27. RPC 1: how to develop RPC framework from scratch
  28. 一次性捋清楚吧,对乱糟糟的,Spring事务扩展机制
  29. 一文彻底弄懂如何选择抽象类还是接口,连续四年百度Java岗必问面试题
  30. Redis常用命令
  31. 一双拖鞋引发的血案,狂神说Java系列笔记
  32. 一、mysql基础安装
  33. 一位程序员的独白:尽管我一生坎坷,Java框架面试基础
  34. Clear it all at once. For the messy, spring transaction extension mechanism
  35. A thorough understanding of how to choose abstract classes or interfaces, baidu Java post must ask interview questions for four consecutive years
  36. Redis common commands
  37. A pair of slippers triggered the murder, crazy God said java series notes
  38. 1、 MySQL basic installation
  39. Monologue of a programmer: despite my ups and downs in my life, Java framework is the foundation of interview
  40. 【大厂面试】三面三问Spring循环依赖,请一定要把这篇看完(建议收藏)
  41. 一线互联网企业中,springboot入门项目
  42. 一篇文带你入门SSM框架Spring开发,帮你快速拿Offer
  43. 【面试资料】Java全集、微服务、大数据、数据结构与算法、机器学习知识最全总结,283页pdf
  44. 【leetcode刷题】24.数组中重复的数字——Java版
  45. 【leetcode刷题】23.对称二叉树——Java版
  46. 【leetcode刷题】22.二叉树的中序遍历——Java版
  47. 【leetcode刷题】21.三数之和——Java版
  48. 【leetcode刷题】20.最长回文子串——Java版
  49. 【leetcode刷题】19.回文链表——Java版
  50. 【leetcode刷题】18.反转链表——Java版
  51. 【leetcode刷题】17.相交链表——Java&python版
  52. 【leetcode刷题】16.环形链表——Java版
  53. 【leetcode刷题】15.汉明距离——Java版
  54. 【leetcode刷题】14.找到所有数组中消失的数字——Java版
  55. 【leetcode刷题】13.比特位计数——Java版
  56. oracle控制用户权限命令
  57. 三年Java开发,继阿里,鲁班二期Java架构师
  58. Oracle必须要启动的服务
  59. 万字长文!深入剖析HashMap,Java基础笔试题大全带答案
  60. 一问Kafka就心慌?我却凭着这份,图灵学院vip课程百度云