使用DOM解析XML文件,、读取xml文件、保存xml、增加节点、修改节点属性、删除节点
<?xml version="1.0" encoding="GB2312" ?>
<PhoneInfo>
<Brand name="华为">
<Type name="P9"/>
</Brand>
<Brand name="苹果">
<Type name="iphone5"/>
<Type name="iphone6"/>
</Brand>
</PhoneInfo>
0、整体代码
package test; import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStreamWriter;
import java.io.UnsupportedEncodingException; import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.transform.OutputKeys;
import javax.xml.transform.Result;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerConfigurationException;
import javax.xml.transform.TransformerException;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult; import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NamedNodeMap;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException; public class XmlTest { Document doc = null;// 创建一个Document对象 public static void main(String[] args) {
XmlTest xml = new XmlTest();
xml.getDocument();
xml.creatNode();
xml.changeType();
xml.showInfo();
xml.deleteNode("SAMSUNG");
xml.showInfo();
xml.saveXml("D:/xml.xml"); } /**
* 获得DOM树
*
*/
public void getDocument() {
// 1、得到DOM工厂解析器工厂实例
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); try {
// 2、从DOM工厂中获得Dom解析器
DocumentBuilder db = factory.newDocumentBuilder();
// 3、解析XML文件获得Document对象,即DOM树
doc = db.parse("收藏信息.xml");
} catch (ParserConfigurationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SAXException | IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} } /**
* 显示xml文档信息 !
*/
public void showInfo() {
// 获取DOM树Brand节点
NodeList BrandName = doc.getElementsByTagName("Brand");
for (int i = 0; i < BrandName.getLength(); i++) {
// 获取第i个Brand元素的信息(返回i元素)
Node brand = BrandName.item(i);
// Element是Node的子类,用Element的getAttribute("属性名")获得元素属性
Element element = (Element) brand;
// 获取第i个Brand元素的name属性
String brandAttribute = element.getAttribute("name");
// 获得所有的子节点
NodeList types = element.getChildNodes();
for (int j = 0; j < types.getLength(); j++) {
Node type = types.item(j);
// 判断是否是元素节点(使用getChildNodes()就要判断)
if (type.getNodeType() == Node.ELEMENT_NODE) {
Element typeEle = (Element) type;
String typeAttribute = typeEle.getAttribute("name");
System.out.println("手机:" + brandAttribute + typeAttribute);
}
} }
} /**
* 新增节点
*
*/
public void creatNode() {
// 创建三星节点
Element brandEle = doc.createElement("Brand");
brandEle.setAttribute("name", "三星");
// 创建型号Note7节点
Element type = doc.createElement("Type");
type.setAttribute("name", "Note7");
// 把note7元素挂到三星元素上
brandEle.appendChild(type);
// 找到PhoneInfo节点
NodeList PhoneInfosNode = doc.getElementsByTagName("PhoneInfo");
for (int i = 0; i < PhoneInfosNode.getLength(); i++) {
Node PhoneInfos = PhoneInfosNode.item(i);
if (PhoneInfos.getNodeType() == Node.ELEMENT_NODE) {
// 把三星节点挂到PhoneInfo上
PhoneInfos.appendChild(brandEle);
} } }
/**
* 保存xml文档
*
* @param path 保存的路径
*/
public void saveXml(String path) {
// 1、创建转换工厂
TransformerFactory factory = TransformerFactory.newInstance(); try {
// 2、从工厂中获得转换器
Transformer Transformer = factory.newTransformer();
// 3、进行转换,如果直接转换可能出现乱码,需要进行格式设置
// 输出文件编码格式设置
Transformer.setOutputProperty(OutputKeys.ENCODING, "gb2312");
// 需要DOM转换的源文件
DOMSource xmlSource = new DOMSource(doc);
// 指定目标路径
StreamResult outputTarget = new StreamResult(new FileOutputStream(
path));
// 使用transform()进行保存xml文件
Transformer.transform(xmlSource, outputTarget); } catch (TransformerConfigurationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (TransformerException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} }
/**
* 更改Brand属性
*
*/
public void changeType(){
//获得节点信息
NodeList brandElements = doc.getElementsByTagName("Brand");
//遍历节点
for (int i = 0; i < brandElements.getLength(); i++) {
Node brands = brandElements.item(i);
Element brand=(Element) brands; String brandAtt = brand.getAttribute("name");
//判断节点属性值
if(brandAtt.equals("三星")){
brand.setAttribute("name", "SAMSUNG");
}
}
}
/**
* 删除指定节点
* @param name 删除的Brand属性名
*/
public void deleteNode(String name){
NodeList brandsEle = doc.getElementsByTagName("Brand");
for (int i = 0; i < brandsEle.getLength(); i++) {
Element brand = (Element) brandsEle.item(i);
String brandAttribute = brand.getAttribute("name");
if(brandAttribute.equals(name)){
doc.getElementsByTagName("PhoneInfo").item(0).removeChild(brand);
} }
}
}
1、通过DocumentBuilderFactory 获得解析工厂,在工厂中获得解析器实例,通过解析器获得DOM树。
/**
* 获得DOM树
*
*/
public void getDocument() {
// 1、得到DOM工厂解析器工厂实例
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); try {
// 2、从DOM工厂中获得Dom解析器
DocumentBuilder db = factory.newDocumentBuilder();
// 3、解析XML文件获得Document对象,即DOM树
doc = db.parse("收藏信息.xml");
} catch (ParserConfigurationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SAXException | IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} }
2、保存xml文件
/**
* 保存xml文档
*
* @param path 保存的路径
*/
public void saveXml(String path) {
// 1、创建转换工厂
TransformerFactory factory = TransformerFactory.newInstance(); try {
// 2、从工厂中获得转换器
Transformer Transformer = factory.newTransformer();
// 3、进行转换,如果直接转换可能出现乱码,需要进行格式设置
// 输出文件编码格式设置
Transformer.setOutputProperty(OutputKeys.ENCODING, "gb2312");
// 需要DOM转换的源文件
DOMSource xmlSource = new DOMSource(doc);
// 指定目标路径
StreamResult outputTarget = new StreamResult(new FileOutputStream(
path));
// 使用transform()进行保存xml文件
Transformer.transform(xmlSource, outputTarget); } catch (TransformerConfigurationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (TransformerException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} }
3、xml文件显示到控制台
/**
* 显示xml文档信息 !
*/
public void showInfo() {
// 获取DOM树Brand节点
NodeList BrandName = doc.getElementsByTagName("Brand");
for (int i = 0; i < BrandName.getLength(); i++) {
// 获取第i个Brand元素的信息(返回i元素)
Node brand = BrandName.item(i);
// Element是Node的子类,用Element的getAttribute("属性名")获得元素属性
Element element = (Element) brand;
// 获取第i个Brand元素的name属性
String brandAttribute = element.getAttribute("name");
// 获得所有的子节点
NodeList types = element.getChildNodes();
for (int j = 0; j < types.getLength(); j++) {
Node type = types.item(j);
// 判断是否是元素节点(使用getChildNodes()就要判断)
if (type.getNodeType() == Node.ELEMENT_NODE) {
Element typeEle = (Element) type;
String typeAttribute = typeEle.getAttribute("name");
System.out.println("手机:" + brandAttribute + typeAttribute);
}
} }
}
4、添加节点Brand:三星,Type:note7
/**
* 新增节点
*
*/
public void creatNode() {
// 创建三星节点
Element brandEle = doc.createElement("Brand");
brandEle.setAttribute("name", "三星");
// 创建型号Note7节点
Element type = doc.createElement("Type");
type.setAttribute("name", "Note7");
// 把note7元素挂到三星元素上
brandEle.appendChild(type);
// 找到PhoneInfo节点
NodeList PhoneInfosNode = doc.getElementsByTagName("PhoneInfo");
for (int i = 0; i < PhoneInfosNode.getLength(); i++) {
Node PhoneInfos = PhoneInfosNode.item(i);
if (PhoneInfos.getNodeType() == Node.ELEMENT_NODE) {
// 把三星节点挂到PhoneInfo上
PhoneInfos.appendChild(brandEle);
} } }
5、修改节点属性,修改"三星"为"SAMSUNG"
/**
* 更改Brand属性
*
*/
public void changeType(){
//获得节点信息
NodeList brandElements = doc.getElementsByTagName("Brand");
//遍历节点
for (int i = 0; i < brandElements.getLength(); i++) {
Node brands = brandElements.item(i);
Element brand=(Element) brands; String brandAtt = brand.getAttribute("name");
//判断节点属性值
if(brandAtt.equals("三星")){
brand.setAttribute("name", "SAMSUNG");
}
}
}
6、删除SAMSUNG节点
/**
* 删除指定节点
* @param name 删除的Brand属性名
*/
public void deleteNode(String name){
NodeList brandsEle = doc.getElementsByTagName("Brand");
for (int i = 0; i < brandsEle.getLength(); i++) {
Element brand = (Element) brandsEle.item(i);
String brandAttribute = brand.getAttribute("name");
if(brandAttribute.equals(name)){
doc.getElementsByTagName("PhoneInfo").item(0).removeChild(brand);
} }
}
7、主方法
public static void main(String[] args) {
XmlTest xml = new XmlTest();
xml.getDocument();
xml.creatNode();
xml.changeType();
xml.showInfo();
xml.deleteNode("SAMSUNG");
xml.showInfo();
xml.saveXml("D:/xml.xml");
}
使用DOM解析XML文件,、读取xml文件、保存xml、增加节点、修改节点属性、删除节点的更多相关文章
- html文件在head标签中引入js地址和直接写js代码,所用时间是不同的,因为引入js地址,文件加载的时候需要通过通讯协议去解析地址,读取外部文件
html文件在head标签中引入js地址和直接写js代码,所用时间是不同的,因为引入js地址,文件加载的时候需要通过通讯协议去解析地址,读取外部文件
- java中的文件读取和文件写出:如何从一个文件中获取内容以及如何向一个文件中写入内容
import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.File; import java.io.Fi ...
- 解决Requests中文乱码【有用】,读取htm文件 读取txt文件报错:UnicodeDecodeError: 'utf-8' codec can't decode byte 0xc8 in position 0
打开这个网址https://blog.csdn.net/chaowanghn/article/details/54889835 python在open读取txt文件时,出现UnicodeDecodeE ...
- java实现xml文件读取并保存到对象
首先浅聊一下解析xml的四种方式: 1.DOM方式:有缺点但是这个缺点却也是他的优点.下面详细介绍: 以树形的层次结构组织节点或信息片断集合,可以获得同一个文档中的多处不同数据.使用起来简单. 优点是 ...
- XML解析(一) DOM解析
XML解析技术主要有三种: (1)DOM(Document Object Model)文档对象模型:是 W3C 组织推荐的解析XML 的一种方式,即官方的XML解析技术. (2)SAX(Simple ...
- 递归方式 DOM 解析(parse) XML
friends.xml <span style="font-size:16px;"><?xml version="1.0" encoding= ...
- java中四种操作(dom、sax、jdom、dom4j)xml方式详解与比较
1)DOM(JAXP Crimson解析器) DOM是用与平台和语言无关的方式表示XML文档的官方W3C标准.DOM是以层次结构组织的节点或信息片断的集合.这个层次结构允许开发人员在树中寻找特 ...
- 深度学习_1_Tensorflow_2_数据_文件读取
tensorflow 数据读取 队列和线程 文件读取, 图片处理 问题:大文件读取,读取速度, 在tensorflow中真正的多线程 子线程读取数据 向队列放数据(如每次100个),主线程学习,不用全 ...
- C#生成PDF文档,读取TXT文件内容
using System.IO;using iTextSharp.text;using iTextSharp.text.pdf; //需要在项目里引用ICSharpCode.SharpZipLib.d ...
随机推荐
- ubuntu 手动安装openssh-server
先用能上网的机器下载:zlib-1.2.5.tar.openssh-5.6p1.tar.gz.openssl-0.9.8o.tar.tar,接下来,准备安装. 步骤如下: 1.首先解压安装zlib:t ...
- 整理自己的.net工具库
前言 今天我会把自己平日整理的工具库给开放出来,提供给有需要的朋友,如果有朋友平常也在积累欢迎提意见,我会乐意采纳并补充完整.按照惯例在文章结尾给出地址^_^. 之前我开放其他源码的时候(Framew ...
- Java面试容易容易出现的一些考点
考点内容是我个人的一点看法,不代表一定是这些,后面会慢慢继续补充 请写出final.finally.finalize的区别 1.final和finally都是关键字.而finalize是一个方法,是属 ...
- 解决 apache poi 转换 word(docx) 文件到 html 文件表格没边框的问题
一.起因 这几天在做电子签章问题,要通过替换docx文件中的占位符生成包含业务数据的合同数据,再转换成html文件,转换成pdf文件.遇到的问题是:通过apache poi转换docx到html时,原 ...
- python--代码统计(进阶版)
在上一篇的随笔中发表了代码统计小程序,但是发表后,我发现,以前写的代码怎么办 写了那么多,怎么就从0开始了呢,,,,我还是个孩子啊,不能这么残忍 于是,代码统计进阶版:统计当前目录下所有指定文件类型的 ...
- hdu--1258--Sum It Up(Map水过)
Sum It Up Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total S ...
- 初笔,JAVA.HelloWorld代码详解
HelloWorld.java //文件名 public class HelloWorld{ public static void main(String[] args){ System.out.pr ...
- 在实际项目中使用LiteDB NoSQL数据库
LiteDB 是一个 NoSQL 数据库,特点是 MongoDB like 和 0 配置.100% 原汁原味的 C# 开发, Release 只有一个 DLL,官方有一下适用场景:移动App,桌面小应 ...
- 网站pv统计脚本
在平时的运维工作中,我们运维人员需要清楚自己网站每天的总访问量.总带宽.ip统计和url统计等.虽然网站已经在服务商那里做了CDN加速,所以网站流量压力都在前方CDN层了像每日PV,带宽,ip统计等数 ...
- 【环境搭建】使用Jekyll搭建Github博客
前言 昨天花了差不多一天的时间,使用Jekyll搭建起了一套Github博客,感觉不错,也特将搭建过程记录下来,方便有需要的朋友自行搭建. 搭建步骤 本环境是在Linux环境下搭建完成的 安装前建议使 ...