博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java 读取xml删除xml节点_使用java解析器删除XML节点
阅读量:6999 次
发布时间:2019-06-27

本文共 1066 字,大约阅读时间需要 3 分钟。

替代DOM方法

或者,您可以使用JDK中的XPath功能来查找值为“13”的“B”元素,然后将其从其父项中删除,而不是进行强力遍历XML文档:

import java.io.File;

import javax.xml.parsers.*;

import javax.xml.transform.*;

import javax.xml.transform.dom.DOMSource;

import javax.xml.transform.stream.StreamResult;

import javax.xml.xpath.*;

import org.w3c.dom.*;

public class Demo {

public static void main(String[] args) throws Exception {

DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();

Document document = dbf.newDocumentBuilder().parse(new File("input.xml"));

XPathFactory xpf = XPathFactory.newInstance();

XPath xpath = xpf.newXPath();

XPathExpression expression = xpath.compile("//A/B[C/E/text()=13]");

Node b13Node = (Node) expression.evaluate(document, XPathConstants.NODE);

b13Node.getParentNode().removeChild(b13Node);

TransformerFactory tf = TransformerFactory.newInstance();

Transformer t = tf.newTransformer();

t.transform(new DOMSource(document), new StreamResult(System.out));

}

}

使用XPath的优点是更容易维护,如果结构更改只是一行代码更改.另外,如果您的文档的深度增长,基于XPath的解决方案保持相同数量的行.

非DOM方法

如果您不想将XML实现为DOM.您可以使用Transformer和stylesheet来删除节点:

转载地址:http://abevl.baihongyu.com/

你可能感兴趣的文章
Restful API 的设计
查看>>
Apache Lucene 8.0.0 发布,Java 全文搜索引擎
查看>>
Sequelize 和 MySQL 对照
查看>>
如何自学编程?学习方法在这里!
查看>>
好程序员web前端分享js剪切板Clipboard.js 使用
查看>>
访问权限,public private protected
查看>>
Kubernetes(一) - Docker管理工具
查看>>
Linux基础命令---文本编辑ex
查看>>
用开放和流动反抗熵增,生态建设终极哲学——保险生态建设 ...
查看>>
web页面渲染(二)
查看>>
半年两轮融资,小程序生态服务平台「即速应用」再获5000万元A+轮融资 ...
查看>>
JVM 常用参数
查看>>
Dat.gui 使用教程
查看>>
Auto Scaling 支持目标追踪伸缩规则
查看>>
阿里敏捷教练:多团队开发一个产品的组织设计和思考
查看>>
java日志规约及配置示例终极总结
查看>>
How Blink Works 中文译文
查看>>
three.js 创建文字的几种方法
查看>>
实现div毛玻璃背景
查看>>
Java虚拟机的组成
查看>>