java对xml 增删改_Java对XML文件增删改查操作示例

本文介绍了如何使用Java对XML文件进行操作,包括创建新书节点、修改《哈里波特》价格、添加属性、删除《三国演义》以及过滤和删除价格低于10的书籍。通过实例展示了DocumentBuilderFactory、DOM解析和XPath查询在实际开发中的应用。
摘要由CSDN通过智能技术生成

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

xml文件:

哈里波特

10

这是一本很好看的书。

三国演义

10

四大名著之一。

水浒

6

四大名著之一。

红楼

5

四大名著之一。

增删改查 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程序设计有所帮助。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值