热门标签 | HotTags
当前位置:  开发笔记 > 前端 > 正文

使用DOM4J解析XML文档,以及使用XPath提取XML文档

使用DOM4J解析XML文档需要首先下载DOM4J工具包。这是个第三方工具包在使用DOM4J解析的时候需要导入DOM4J的JAR包下载DOM4J工具包-》在MyEclipse中新建lib文件夹-》在DOM4J中导入JAR包。可以全部导入,也可以导入...SyntaxHighlig

 

 

 

使用DOM4J解析XML文档

需要首先下载DOM4J工具包。这是个第三方工具包

在使用DOM4J解析的时候需要导入 DOM4J的JAR包

下载DOM4J工具包-》在MyEclipse中新建lib文件夹-》在DOM4J中导入JAR包。可以全部导入,也可以导入指定的JAR包,这里我只导入dom4j 的jar包,.--》 右键点击dom4j的jar -》 Build Path -> add to Build Path -> 看见变成奶瓶后就导入成功了

 

进行增删改查

 

 


文档为:

 

 

[html] 
 
 
<书架>  
  <书>  
    <书名 name="xxxxx">第一本书   
    <作者>六道01   
    <售价>100  
     
  <书>  
    <书名>第二本书   
    <作者>六道02   
    <售价>200  
    
 

<书架>
  <书>
    <书名 name="xxxxx">第一本书 
    <作者>六道01 
    <售价>100
   
  <书>
    <书名>第二本书 
    <作者>六道02 
    <售价>200
 

 

 


程序为:

 

 

[java] 
import java.io.File; 
import java.io.FileNotFoundException; 
import java.io.FileOutputStream; 
import java.io.IOException; 
import java.io.UnsupportedEncodingException; 
import java.util.List; 
 
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; 
 
//使用dom4j解析XML文档  
public class Demo1 

    // 读取XML第二本书的: <书名>第二本书  
    // 读取!!  
    @Test 
    public void read() throws Exception 
    { 
        // 获得document  
        SAXReader reader = new SAXReader(); 
        Document document = reader.read(new File("src/MyBook.xml")); 
 
        // 获得根节点  
        Element root = document.getRootElement(); 
        // 通过elements获得 素有包含书的标签的 文档,并再获得第二个标签的书 get(1);  
        // 需要强转 因为通过elements获得的是list集合 里面是object 类型  
        Element book = (Element) root.elements("书").get(1); 
        // 获得书里面的内容  
        String value = book.element("书名").getText(); 
        System.out.println(value); 
 
        // 获得里面的属性的值  
        // 第一本书才有属性 所以get(0)  
        Element book2 = (Element) root.elements("书").get(0); 
        // 获得书里面的内容  
        String value2 = book2.element("书名").attribute("name").getValue(); 
        System.out.println(value2); 
 
    } 
 
    // 写入  
    // 在第一本书上添加一个新的售价 :<售价> 250元   
    // 写入的时候注意编码的问题 默认使用GB2312  
    @Test 
    public void add() throws DocumentException, IOException, 
            FileNotFoundException 
    { 
        // 获得document  
        SAXReader reader = new SAXReader(); 
        Document document = reader.read(new File("src/MyBook.xml")); 
 
        Element book = document.getRootElement().element("书"); 
        book.addElement("售价").setText("250元"); 
 
        // 格式化输入器。 createPrettyPrint创建漂亮的格式化输入器  
        OutputFormat format = OutputFormat.createPrettyPrint(); 
        // 文档是什么类型格式化输入器就是什么类型  
        format.setEncoding("UTF-8"); 
 
        // 更新XML文档 ,将内存中数据写入XML文档当中去  
        // 这里用的是字节流,用字符流的话不会查码表,如果写入和输出的编码不一样则会乱码  
        // 用字节流会查自己提供的码表。  
        XMLWriter writer = new XMLWriter( 
                new FileOutputStream("src/MyBook.xml"), format); 
        // 开始写入  
        writer.write(document); 
        writer.close(); 
 
    } 
 
    // 在一本书的指定的位置添加售价:<售价> 350元   只要更改保存了所有孩子的list集合的顺序  
    @Test 
    public void add2() throws DocumentException, IOException, 
            FileNotFoundException 
    { 
        // 获得document  
        SAXReader reader = new SAXReader(); 
        Document document = reader.read(new File("src/MyBook.xml")); 
 
        // 得到书的标签  
        Element book = document.getRootElement().element("书"); 
        // 将获得的书的标签存入 list集合  
        // list集合中的集合的样子是:[书名,作者,售价] 现在在售价前面添加售价  
        List list = book.elements(); 
 
        // 获得售价  
        Element price = DocumentHelper.createElement("售价"); 
        // 设置售价内容  
        price.setText("350元"); 
 
        // 第二个[书名,作者,售价,售价]  
        list.add(2, price); 
 
        // 将内存中document写入xml文档  
        OutputFormat format = OutputFormat.createPrettyPrint(); 
        format.setEncoding("UTF-8"); 
 
        XMLWriter writer = new XMLWriter( 
                new FileOutputStream("src/MyBook.xml"), format); 
        // 开始写入  
        writer.write(document); 
        writer.close(); 
 
    } 
     
     
    //删除 上面add2添加的售价节点  
    @Test 
    public void delete() throws DocumentException, Exception 
    { 
        SAXReader reader = new SAXReader(); 
        Document document = reader.read(new File("src/MyBook.xml")); 
         
        //获得售价标签  
        Element price = document.getRootElement().element("书").element("售价"); 
        //删除售价  
        price.getParent().remove(price); 
         
        //更新XML文档  
        OutputFormat format = OutputFormat.createPrettyPrint(); 
        format.setEncoding("UTF-8"); 
 
        XMLWriter writer = new XMLWriter( 
                new FileOutputStream("src/MyBook.xml"), format); 
        // 开始写入  
        writer.write(document); 
        writer.close(); 
    } 
     
    //更新数据 改变第二本书的作者  
    @Test 
    public void updata() throws Exception 
    { 
        SAXReader reader = new SAXReader(); 
        Document document = reader.read(new File("src/MyBook.xml")); 
         
        Element book = (Element) document.getRootElement().elements("书").get(1); 
        book.element("作者").setText("六道03"); 
         
         
        //更新数据  
        OutputFormat format = OutputFormat.createPrettyPrint(); 
        format.setEncoding("UTF-8"); 
 
        XMLWriter writer = new XMLWriter( 
                new FileOutputStream("src/MyBook.xml"), format); 
        // 开始写入  
        writer.write(document); 
        writer.close(); 
    } 
     
     
 

import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.util.List;

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;

//使用dom4j解析XML文档
public class Demo1
{
 // 读取XML第二本书的: <书名>第二本书
 // 读取!!
 @Test
 public void read() throws Exception
 {
  // 获得document
  SAXReader reader = new SAXReader();
  Document document = reader.read(new File("src/MyBook.xml"));

  // 获得根节点
  Element root = document.getRootElement();
  // 通过elements获得 素有包含书的标签的 文档,并再获得第二个标签的书 get(1);
  // 需要强转 因为通过elements获得的是list集合 里面是object 类型
  Element book = (Element) root.elements("书").get(1);
  // 获得书里面的内容
  String value = book.element("书名").getText();
  System.out.println(value);

  // 获得里面的属性的值
  // 第一本书才有属性 所以get(0)
  Element book2 = (Element) root.elements("书").get(0);
  // 获得书里面的内容
  String value2 = book2.element("书名").attribute("name").getValue();
  System.out.println(value2);

 }

 // 写入
 // 在第一本书上添加一个新的售价 :<售价> 250元
 // 写入的时候注意编码的问题 默认使用GB2312
 @Test
 public void add() throws DocumentException, IOException,
   FileNotFoundException
 {
  // 获得document
  SAXReader reader = new SAXReader();
  Document document = reader.read(new File("src/MyBook.xml"));

  Element book = document.getRootElement().element("书");
  book.addElement("售价").setText("250元");

  // 格式化输入器。 createPrettyPrint创建漂亮的格式化输入器
  OutputFormat format = OutputFormat.createPrettyPrint();
  // 文档是什么类型格式化输入器就是什么类型
  format.setEncoding("UTF-8");

  // 更新XML文档 ,将内存中数据写入XML文档当中去
  // 这里用的是字节流,用字符流的话不会查码表,如果写入和输出的编码不一样则会乱码
  // 用字节流会查自己提供的码表。
  XMLWriter writer = new XMLWriter(
    new FileOutputStream("src/MyBook.xml"), format);
  // 开始写入
  writer.write(document);
  writer.close();

 }

 // 在一本书的指定的位置添加售价:<售价> 350元   只要更改保存了所有孩子的list集合的顺序
 @Test
 public void add2() throws DocumentException, IOException,
   FileNotFoundException
 {
  // 获得document
  SAXReader reader = new SAXReader();
  Document document = reader.read(new File("src/MyBook.xml"));

  // 得到书的标签
  Element book = document.getRootElement().element("书");
  // 将获得的书的标签存入 list集合
  // list集合中的集合的样子是:[书名,作者,售价] 现在在售价前面添加售价
  List list = book.elements();

  // 获得售价
  Element price = DocumentHelper.createElement("售价");
  // 设置售价内容
  price.setText("350元");

  // 第二个[书名,作者,售价,售价]
  list.add(2, price);

  // 将内存中document写入xml文档
  OutputFormat format = OutputFormat.createPrettyPrint();
  format.setEncoding("UTF-8");

  XMLWriter writer = new XMLWriter(
    new FileOutputStream("src/MyBook.xml"), format);
  // 开始写入
  writer.write(document);
  writer.close();

 }
 
 
 //删除 上面add2添加的售价节点
 @Test
 public void delete() throws DocumentException, Exception
 {
  SAXReader reader = new SAXReader();
  Document document = reader.read(new File("src/MyBook.xml"));
  
  //获得售价标签
  Element price = document.getRootElement().element("书").element("售价");
  //删除售价
  price.getParent().remove(price);
  
  //更新XML文档
  OutputFormat format = OutputFormat.createPrettyPrint();
  format.setEncoding("UTF-8");

  XMLWriter writer = new XMLWriter(
    new FileOutputStream("src/MyBook.xml"), format);
  // 开始写入
  writer.write(document);
  writer.close();
 }
 
 //更新数据 改变第二本书的作者
 @Test
 public void updata() throws Exception
 {
  SAXReader reader = new SAXReader();
  Document document = reader.read(new File("src/MyBook.xml"));
  
  Element book = (Element) document.getRootElement().elements("书").get(1);
  book.element("作者").setText("六道03");
  
  
  //更新数据
  OutputFormat format = OutputFormat.createPrettyPrint();
  format.setEncoding("UTF-8");

  XMLWriter writer = new XMLWriter(
    new FileOutputStream("src/MyBook.xml"), format);
  // 开始写入
  writer.write(document);
  writer.close();
 }
 
 

}

 

 

 

 


****************************************************************************邪恶的分割***********************************************************************************************

 

 

 

下面使用XPath提取XML文档

需求:在XML文档中有用户名密码,现在编程定义用户名密码 ,测试用户名密码是否匹配,如果存在并匹配,那么打印登陆成功,如果不匹配,那么打印登陆失败。

 


xml文档:

 

 

[html
 
 
     
     
 



 
 

 

 

 

程序:


[java] 
import java.io.File; 
 
import org.dom4j.Document; 
import org.dom4j.DocumentException; 
import org.dom4j.Node; 
import org.dom4j.io.SAXReader; 
 
public class FindUsers 

    /**
     * 查找users.xml文档是否有和用户匹配的用户名和密码
     * 
     * @param args
     * @throws Exception
     */ 
    public static void main(String[] args) throws Exception 
    { 
        String username = "aaa"; 
        String password = "123"; 
 
        // 检测xml文档中是否有匹配的  
        SAXReader reader = new SAXReader(); 
        Document document = reader.read(new File("src/users.xml")); 
 
        // 使用XPath解析XML文档, 查找用户名和密码是否相匹配  
        //注意在这里 等于用户名和密码时 用到单引号  
        Node node = document.selectSingleNode("//user[@username = &#39;" + username 
                + "&#39; and @password = &#39;" + password + "&#39; ]"); 
        if(node==null) 
        { 
            System.out.println("用户名或密码错误"); 
        } 
        else 
        { 
            System.out.println("恭喜登陆成功"); 
        } 
 
    } 
 

import java.io.File;

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

public class FindUsers
{
 /**
  * 查找users.xml文档是否有和用户匹配的用户名和密码
  *
  * @param args
  * @throws Exception
  */
 public static void main(String[] args) throws Exception
 {
  String username = "aaa";
  String password = "123";

  // 检测xml文档中是否有匹配的
  SAXReader reader = new SAXReader();
  Document document = reader.read(new File("src/users.xml"));

  // 使用XPath解析XML文档, 查找用户名和密码是否相匹配
  //注意在这里 等于用户名和密码时 用到单引号
  Node node = document.selectSingleNode("//user[@username = &#39;" + username
    + "&#39; and @password = &#39;" + password + "&#39; ]");
  if(node==null)
  {
   System.out.println("用户名或密码错误");
  }
  else
  {
   System.out.println("恭喜登陆成功");
  }

 }

}


 


推荐阅读
  • 如何在Java中高效构建WebService
    本文介绍了如何利用XFire框架在Java中高效构建WebService。XFire是一个轻量级、高性能的Java SOAP框架,能够简化WebService的开发流程。通过结合MyEclipse集成开发环境,开发者可以更便捷地进行项目配置和代码编写,从而提高开发效率。此外,文章还详细探讨了XFire的关键特性和最佳实践,为读者提供了实用的参考。 ... [详细]
  • wxParse 0.3:微信小程序中的高级 HTML 和 Markdown 富文本解析器,全面支持多级嵌套与 Emoji 表情
    wxParse 0.3 是一款专为微信小程序设计的高级富文本解析器,支持 HTML 和 Markdown 转换为 WXML 可视化格式。该组件不仅能够处理复杂的多级嵌套结构,还全面支持 Emoji 表情,极大地提升了内容展示的多样性和用户体验。 ... [详细]
  • Spring Security 认证模块的项目构建与初始化
    本文详细介绍了如何构建和初始化Spring Security认证模块的项目。首先,通过创建一个分布式Maven聚合工程,该工程包含四个模块,分别为core、browser(用于演示)、app等,以构成完整的SeehopeSecurity项目。在项目构建过程中,还涉及日志生成机制,确保能够输出关键信息,便于调试和监控。 ... [详细]
  • 使用 MyEclipse 和 TestNG 测试框架在 Java 中高效进行单元测试
    通过MyEclipse集成TestNG测试框架,可以在Java开发中高效地进行单元测试。本文介绍了在JDK 1.8.0_121和MyEclipse 10.0离线环境下配置和使用TestNG的具体步骤,帮助开发者提高测试效率和代码质量。 ... [详细]
  • 如何运用蒙特卡洛方法计算NPV:计算机专业毕业设计遇到难题怎么办?
    许多计算机科学专业的学生在大学期间都会遇到这样的困扰:课堂上教授的内容往往偏向理论,实际应用的知识点讲解得较为浅显和概括,导致在进行毕业设计时,如运用蒙特卡洛方法计算净现值(NPV)等复杂问题时感到无从下手。本文旨在探讨如何通过深入理解和实践蒙特卡洛模拟技术,解决这类计算难题,为学生的毕业设计提供实用指导。 ... [详细]
  • Java中高级工程师面试必备:JVM核心知识点全面解析
    对于软件开发人员而言,随着技术框架的不断演进和成熟,许多高级功能已经被高度封装,使得初级开发者只需掌握基本用法即可迅速完成项目。然而,对于中高级工程师而言,深入了解Java虚拟机(JVM)的核心知识点是必不可少的。这不仅有助于优化性能和解决复杂问题,还能在面试中脱颖而出。本文将全面解析JVM的关键概念和技术细节,帮助读者全面提升技术水平。 ... [详细]
  • 深入解析Tomcat:开发者的实用指南
    深入解析Tomcat:开发者的实用指南 ... [详细]
  • 在处理大规模并发请求时,传统的多线程或多进程模型往往无法有效解决性能瓶颈问题。尽管它们在处理小规模任务时能提升效率,但在高并发场景下,系统资源的过度消耗和上下文切换的开销会显著降低整体性能。相比之下,Python 的 `asyncio` 模块通过协程提供了一种轻量级且高效的并发解决方案。本文将深入解析 `asyncio` 模块的原理及其在实际应用中的优化技巧,帮助开发者更好地利用协程技术提升程序性能。 ... [详细]
  • 可转债数据智能抓取与分析平台优化
    本项目旨在优化可转债数据的智能抓取与分析平台。通过爬取集思录上的可转债信息(排除已发布赎回的债券),并结合安道全教授提出的三条安全线投资策略,新增了建仓线、加仓线和重仓线,以提供更精准的投资建议。 ... [详细]
  • 如何构建基于Spring MVC框架的Java Web应用项目
    在构建基于Spring MVC框架的Java Web应用项目时,首先应创建一个新的动态Web项目。接着,需将必要的JAR包导入至WebContent/WEB-INF/lib目录下,确保包括Spring核心库及相关依赖。如遇缺失的JAR包,可向社区求助或通过Maven等工具自动下载。正确配置后,即可开始搭建应用结构与功能模块。 ... [详细]
  • 本文深入探讨了 HTML 中的 `margin` 属性,详细解析了其基本特性和应用场景。文章不仅介绍了 `margin` 的基本概念,还重点讨论了垂直外边距合并现象,并分析了 `margin` 在块级元素与内联元素中的不同表现。通过实例和代码示例,帮助读者全面理解 `margin` 的使用技巧和常见问题。 ... [详细]
  • 在椭圆形状设计中,色彩搭配方案对视觉效果和用户体验至关重要。本文分析了不同色彩组合在椭圆形状设计中的应用效果,特别探讨了白色背景与绿色文字的搭配,指出长期观看这种配色可能会导致视觉疲劳。通过引入多种色彩搭配方案,本文旨在为设计师提供更加科学和舒适的色彩选择建议。 ... [详细]
  • SpringBoot启动脚本详解:BAT文件应用与基础入门指南(SpringBoot系列第1篇)
    如果你还在为SSM框架的复杂搭建过程和繁琐的配置文件而烦恼,那么SpringBoot将是你的一大福音。作为SpringBoot系列的第一篇文章,本文详细介绍了如何使用BAT文件来启动SpringBoot应用,并提供了基础入门指南,帮助开发者快速上手,简化开发流程。 ... [详细]
  • 手机上编写和运行PHP代码的最佳软件推荐 ... [详细]
  • Apache Maven 3.5.0 版本的发布带来了多项重要特性和性能优化。该版本不仅改进了构建过程的效率,还增强了对复杂项目结构的支持。通过引入新的依赖解析机制和优化的插件系统,Maven 3.5.0 在提升用户体验的同时,也确保了更高的稳定性和兼容性。此外,该版本还修复了多个已知问题,进一步提升了整体的可靠性和安全性。 ... [详细]
author-avatar
忆丨残年_686
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有