使用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 ...
随机推荐
- HA分布式集群二hive配置
一,概念 hive:是一种数据仓库,数据储存在:hdfs上,hsql是由替换简单的map-reduce,hive通过mysql来记录映射数据 二,安装 1,mysql安装: 1,检测是否有mariad ...
- python3.6成功安装scrapy
本文基于环境:win10(64)+python3.6(64) 第一次直接pip install scrapy,安装出错,错误提示 error: Microsoft Visual C++ 14.0 is ...
- IPython使用学习笔记
学习<利用python进行数据分析>第三章 IPython:一种交互式计算和开发环境的笔记,共享给大家,同时为自己作为备忘用. 安装ipython用pip即可.ps.博主用的是win7系统 ...
- HTML-CSS相关(2)
[CSS常用文本属性] 1,字体.字号类: ① font-weight:字体粗细. bold-加粗 noemal-正常 lighter-细体 也可以使用100-900数值,400表示normal,70 ...
- Microsoft Edge 浏览器远程代码执行漏洞POC及细节(CVE-2017-8641)
2017年8月8日,CVE官网公布了CVE-2017-8641,在其网上的描述为: 意思是说,黑客可以通过在网页中嵌入恶意构造的javascript代码,使得微软的浏览器(如Edege),在打开这个网 ...
- noip普及组2004 火星人
火星人 描述 人类终于登上了火星的土地并且见到了神秘的火星人.人类和火星人都无法理解对方的语言,但是我们的科学家发明了一种用数字交流的方法.这种交流方法是这样的,首先,火星人把一个非常大的数字告诉人类 ...
- git 生成公钥、私钥方法与clone使用方法
我的配置流程 Git配置 Git安装完之后,需做git配置.打开git bash,分别执行以下两句命令 git config --global user.name "用户名" gi ...
- wmic 获得系统硬件信息
wmic扩展了wmi系统管理指令,提供了命令行接口和批处理执行系统管理的工具.通过别名机制将命令转为对wmi命名空间的操作 1.获得cpu信息 2.获得cpu 核数 3.获得内存条信息
- 【Spring 核心】装配bean(二) JavaConfig装配
前面介绍完了组件扫描和自动装配,这里再来看一下装配bean的另一种方式JavaConfig. 包路径: src/main/java com.bonc-|--config--|--CDPlayerCon ...
- Python常用排序算法
1.冒泡排序 思路:将左右元素两两相比较,将值小的放在列表的头部,值大的放到列表的尾部 效率:O(n²) def bubble_sort(li): for i in range(len(li)-1): ...