Java对XML文件增删改查操作示例

 更新时间:2018年12月22日 11:27:38   作者:秋夜雨微凉  
这篇文章主要介绍了Java对XML文件增删改查操作,结合完整实例形式分析了java针对xml格式数据的常见读写、增删改查等操作技巧,需要的朋友可以参考下

本文实例讲述了Java对XML文件增删改查操作。分享给大家供大家参考,具体如下:

xml文件:

<?xml version="1.0" encoding="UTF-8"?>
<books>
  <book>
    <name>哈里波特</name>
    <price>10</price>
    <memo>这是一本很好看的书。</memo>
  </book>
  <book id="B02">
    <name>三国演义</name>
    <price>10</price>
    <memo>四大名著之一。</memo>
  </book>
  <book id="B03">
    <name>水浒</name>
    <price>6</price>
    <memo>四大名著之一。</memo>
  </book>
  <book id="B04">
    <name>红楼</name>
    <price>5</price>
    <memo>四大名著之一。</memo>
  </book>
</books>

增删改查 Test.java

import java.io.File;
import java.io.FileOutputStream;
import org.w3c.dom.*;
import javax.xml.parsers.*;
import javax.xml.transform.*;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.*;
import javax.xml.xpath.*;
public class Test {
  public static void main(String[] args) {
    DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
    Element theBook = null, theElem = null, root = null;
    try {
      factory.setIgnoringElementContentWhitespace(true);
      DocumentBuilder db = factory.newDocumentBuilder();
      Document xmldoc = (Document) db.parse(new File("Test.xml"));
      root = xmldoc.getDocumentElement();
      // --- 新建一本书开始 ----
      theBook = xmldoc.createElement("book");
      theElem = xmldoc.createElement("name");
      theElem.setTextContent("新书");
      theBook.appendChild(theElem);
      theElem = xmldoc.createElement("price");
      theElem.setTextContent("20");
      theBook.appendChild(theElem);
      theElem = xmldoc.createElement("memo");
      theElem.setTextContent("新书的更好看。");
      theBook.appendChild(theElem);
      root.appendChild(theBook);
      System.out.println("--- 新建一本书开始 ----");
      output(xmldoc);
      // --- 新建一本书完成 ----
      // --- 下面对《哈里波特》做一些修改。 ----
      // --- 查询找《哈里波特》----
      theBook = (Element) selectSingleNode("/books/book[name='哈里波特']",
          root);
      System.out.println("--- 查询找《哈里波特》 ----");
      output(theBook);
      // --- 此时修改这本书的价格 -----
      theBook.getElementsByTagName("price").item(0).setTextContent("15");// getElementsByTagName返回的是NodeList,所以要跟上item(0)。另外,getElementsByTagName("price")相当于xpath的".//price"。
      System.out.println("--- 此时修改这本书的价格 ----");
      output(theBook);
      // --- 另外还想加一个属性id,值为B01 ----
      theBook.setAttribute("id", "B01");
      System.out.println("--- 另外还想加一个属性id,值为B01 ----");
      output(theBook);
      // --- 对《哈里波特》修改完成。 ----
      // --- 要用id属性删除《三国演义》这本书 ----
      theBook = (Element) selectSingleNode("/books/book[@id='B02']", root);
      System.out.println("--- 要用id属性删除《三国演义》这本书 ----");
      output(theBook);
      theBook.getParentNode().removeChild(theBook);
      System.out.println("--- 删除后的XML ----");
      output(xmldoc);
      // --- 再将所有价格低于10的书删除 ----
      NodeList someBooks = selectNodes("/books/book[price<10]", root);
      System.out.println("--- 再将所有价格低于10的书删除 ---");
      System.out.println("--- 符合条件的书有 " + someBooks.getLength()
          + "本。 ---");
      for (int i = 0; i < someBooks.getLength(); i++) {
        someBooks.item(i).getParentNode().removeChild(someBooks.item(i));
      }
      output(xmldoc);
      saveXml("Test1_Edited.xml", xmldoc);
    } catch (Exception e) {
      e.printStackTrace();
    }
  }
  /**
   * 将node的XML字符串输出到控制台
   *
   * @param node
   */
  public static void output(Node node) {
    TransformerFactory transFactory = TransformerFactory.newInstance();
    try {
      Transformer transformer = transFactory.newTransformer();
      transformer.setOutputProperty("encoding", "gb2312");
      transformer.setOutputProperty("indent", "yes");
      DOMSource source = new DOMSource();
      source.setNode(node);
      StreamResult result = new StreamResult();
      result.setOutputStream(System.out);
      transformer.transform(source, result);
    } catch (Exception e) {
      e.printStackTrace();
    }
  }
  /**
   * 查找节点,并返回第一个符合条件节点
   *
   * @param express
   * @param source
   * @return
   */
  public static Node selectSingleNode(String express, Object source) {
    Node result = null;
    XPathFactory xpathFactory = XPathFactory.newInstance();
    XPath xpath = xpathFactory.newXPath();
    try {
      result = (Node) xpath.evaluate(express, source, XPathConstants.NODE);
    } catch (XPathExpressionException e) {
      e.printStackTrace();
    }
    return result;
  }
  /**
   * 查找节点,返回符合条件的节点集。
   * @param express
   * @param source
   * @return
   */
  public static NodeList selectNodes(String express, Object source) {
    NodeList result = null;
    XPathFactory xpathFactory = XPathFactory.newInstance();
    XPath xpath = xpathFactory.newXPath();
    try {
      result = (NodeList) xpath.evaluate(express, source,
          XPathConstants.NODESET);
    } catch (XPathExpressionException e) {
      e.printStackTrace();
    }
    return result;
  }
  /**
   * 将Document输出到文件
   * @param fileName
   * @param doc
   */
  public static void saveXml(String fileName, Document doc) {
    TransformerFactory transFactory = TransformerFactory.newInstance();
    try {
      Transformer transformer = transFactory.newTransformer();
      transformer.setOutputProperty("indent", "yes");
      DOMSource source = new DOMSource();
      source.setNode(doc);
      StreamResult result = new StreamResult();
      result.setOutputStream(new FileOutputStream(fileName));
      transformer.transform(source, result);
    } catch (Exception e) {
      e.printStackTrace();
    }
  }
}

PS:这里再为大家提供几款关于xml操作的在线工具供大家参考使用:

在线XML/JSON互相转换工具:
http://tools.jb51.net/code/xmljson

在线格式化XML/在线压缩XML
http://tools.jb51.net/code/xmlformat

XML在线压缩/格式化工具:
http://tools.jb51.net/code/xml_format_compress

XML代码在线格式化美化工具:
http://tools.jb51.net/code/xmlcodeformat

更多关于java算法相关内容感兴趣的读者可查看本站专题:《Java数据结构与算法教程》、《Java操作DOM节点技巧总结》、《Java文件与目录操作技巧汇总》和《Java缓存操作技巧汇总

希望本文所述对大家java程序设计有所帮助。

相关文章

  • JAVA IO的3种类型区别解析

    JAVA IO的3种类型区别解析

    这篇文章主要介绍了JAVA IO的3种类型解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-10-10
  • Java设计模式之java状态模式详解

    Java设计模式之java状态模式详解

    这篇文章主要介绍了Java设计模式之状态模式定义与用法,结合具体实例形式详细分析了Java状态模式的概念、原理、定义及相关操作技巧,需要的朋友可以参考下
    2021-09-09
  • Spring Boot Aop执行顺序深入探究

    Spring Boot Aop执行顺序深入探究

    这篇文章主要为大家介绍了Spring Boot Aop执行顺序深入探究,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2024-01-01
  • Spring Boot日志的打印与持久化详细解析

    Spring Boot日志的打印与持久化详细解析

    Spring Boot默认使用SLF4J+Logback 记录日志,并提供了默认配置,即使我们不进行任何额外配,也可以使用SLF4J+Logback进行日志输出
    2022-07-07
  • Java 十大排序算法之希尔排序刨析

    Java 十大排序算法之希尔排序刨析

    希尔排序是希尔(Donald Shell)于1959年提出的一种排序算法。希尔排序也是一种插入排序,它是简单插入排序经过改进之后的一个更高效的版本,也称为缩小增量排序,同时该算法是冲破O(n2)的第一批算法之一。本文会以图解的方式详细介绍希尔排序的基本思想及其代码实现
    2021-11-11
  • Java各种锁在工作中使用场景和细节经验总结

    Java各种锁在工作中使用场景和细节经验总结

    本章主要说一说锁在工作中的使用场景,主要以 synchronized 和 CountDownLatch 为例,会分别描述一下这两种锁的使用场景和姿势
    2022-03-03
  • SpringBoot2.6.x升级后循环依赖及Swagger无法使用问题

    SpringBoot2.6.x升级后循环依赖及Swagger无法使用问题

    这篇文章主要为大家介绍了SpringBoot2.6.x升级后循环依赖及Swagger无法使用问题,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-06-06
  • 浅谈Java注解和动态代理

    浅谈Java注解和动态代理

    这篇文章主要介绍了Java中有关注解和动态代理的一些知识,涉及了Annotation、数据类型等相关内容,需要的朋友可以参考下。
    2017-09-09
  • SpringBoot 如何优雅的实现跨服务器上传文件的示例

    SpringBoot 如何优雅的实现跨服务器上传文件的示例

    这篇文章主要介绍了SpringBoot 如何优雅的实现跨服务器上传文件的示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2006-11-11
  • Java源码解析CopyOnWriteArrayList的讲解

    Java源码解析CopyOnWriteArrayList的讲解

    今天小编就为大家分享一篇关于Java源码解析CopyOnWriteArrayList的讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-01-01

最新评论