使用Dom生成xml文件和解析xml文件

本文涉及的产品
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
简介: xml这种文件格式在很多时候都是很适合我们用来存取数据的,所以利用程序来生成xml文件和解析xml文件就显得比较重要了。在dom中是把每一个元素都看做是一个节点Node的,所有页面上的属性、元素等都是继承自Node的,所以当获取到的是一个Node,而你知道它实际的类型并需要使用的时候就可能会需要进行类型转换了。

xml这种文件格式在很多时候都是很适合我们用来存取数据的,所以利用程序来生成xml文件和解析xml文件就显得比较重要了。在dom中是把每一个元素都看做是一个节点Node的,所有页面上的属性、元素等都是继承自Node的,所以当获取到的是一个Node,而你知道它实际的类型并需要使用的时候就可能会需要进行类型转换了。

Element root = document.getDocumentElement();//获取根节点

下面是代码:

 

生成xml:

public void geneXmlByDom() throws Exception {
		//step1:获得一个DocumentBuilderFactory
		DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
		//step2:获得一个DocumentBuilder
		DocumentBuilder db = factory.newDocumentBuilder();
		//step3:新建一个Document对象
		Document document = db.newDocument();
		//step4:创建一个根节点
		Element rootElement = document.createElement("Persons");
		for (int i=0;i<5;i++) {
			//step5:创建一个节点
			Element person = document.createElement("person");
			//step6:为该节点设定属性
			person.setAttribute("id", "id_"+i);
			Element name = document.createElement("name");
			//为节点设定文本内容
			name.setTextContent("name_"+i);
			Element address = document.createElement("address");
			address.setTextContent("address_"+i);
			Element email = document.createElement("email");
			email.setTextContent("email_"+i);
			person.appendChild(name);
			person.appendChild(address);
			person.appendChild(email);
			//step7:为某一元素节点设立子节点
			rootElement.appendChild(person);
		}
		//step8:把刚刚建立的根节点添加到document对象中
		document.appendChild(rootElement);
		//step9:获得一个TransformerFactory对象
		TransformerFactory transformerFactory = TransformerFactory.newInstance();
		//step10:获得一个Transformer对象
		Transformer transformer = transformerFactory.newTransformer();
		//step11:把document对象用一个DOMSource对象包装起来
		Source xmlSource = new DOMSource(document);
		//step12:建立一个存储目标对象
		Result outputTarget = new StreamResult(new File("persons.xml"));
		//step13:生成相应的xml文件
		transformer.transform(xmlSource, outputTarget);
	}

 

 生成的xml文件是这个样子

<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<Persons>
	<person id="id_0">
		<name>name_0</name>
		<address>address_0</address>
		<email>email_0</email>
	</person>
	<person id="id_1">
		<name>name_1</name>
		<address>address_1</address>
		<email>email_1</email>
	</person>
	<person id="id_2">
		<name>name_2</name>
		<address>address_2</address>
		<email>email_2</email>
	</person>
	<person id="id_3">
		<name>name_3</name>
		<address>address_3</address>
		<email>email_3</email>
	</person>
	<person id="id_4">
		<name>name_4</name>
		<address>address_4</address>
		<email>email_4</email>
	</person>
</Persons>

 

在进行输出写到文件的时候可以设置一些Transformer输出的参数,如xml的编码,或者输出形式等。

		transformer.setOutputProperty("encoding", "UTF-8");//设定文档编码,属性也可以使用OutputKeys的静态常量属性设定
		transformer.setOutputProperty(OutputKeys.METHOD, "xml");//输出方式,可以是xml、html和text

 

 

下面的解析也是基于这个文件的。

 

解析xml:

public void parseXmlByDom() throws Exception {
		//step1:获得DocumentBuilderFactory
		DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
		//step2:获得DocumentBuilder
		DocumentBuilder db = factory.newDocumentBuilder();
		//step3:把需要解析的xml文件加载到一个document对象中
		Document document = db.parse("persons.xml");
		//获取所有名称为person的元素
		NodeList nodeList = document.getElementsByTagName("person");
		for (int i=0;i<nodeList.getLength();i++) {
			//因为这里我知道它就是一个Element对象,所以进行了强转
			Element person = (Element)nodeList.item(i);
			//获得Element对象的属性
			String id = person.getAttribute("id");
			//因为这里我知道只有一个对象,所以就直接item(0)了,
			//因为Dom是把每个对象都看做是一个节点的,所以如果在item(0)的时候直接取getNodeValue()是取不到值的,
			//只有是TextNode的时候用那个方法才可以取到值,如果想直接取值就用getTextContent()
			String name = person.getElementsByTagName("name").item(0).getTextContent();
			String address = person.getElementsByTagName("address").item(0).getTextContent();
			String email = person.getElementsByTagName("email").item(0).getTextContent();
			System.out.println(" id = "+id+" \r\n name = "+name+" \r\n address = "+address+" \r\n email = "+email);
			System.out.println("-------------------------------------");
		}
		
	}

 解析后输出的结果:

 id = id_0 
 name = name_0 
 address = address_0 
 email = email_0
-------------------------------------
 id = id_1 
 name = name_1 
 address = address_1 
 email = email_1
-------------------------------------
 id = id_2 
 name = name_2 
 address = address_2 
 email = email_2
-------------------------------------
 id = id_3 
 name = name_3 
 address = address_3 
 email = email_3
-------------------------------------
 id = id_4 
 name = name_4 
 address = address_4 
 email = email_4
-------------------------------------

 

目录
相关文章
|
2月前
|
JavaScript 前端开发 Go
CSS 与 JS 对 DOM 解析和渲染的影响
【10月更文挑战第16天】CSS 和 JS 会在一定程度上影响 DOM 解析和渲染,了解它们之间的相互作用以及采取适当的优化措施是非常重要的。通过合理的布局和加载策略,可以提高网页的性能和用户体验,确保页面能够快速、流畅地呈现给用户。在实际开发中,要根据具体情况进行权衡和调整,以达到最佳的效果。
|
1月前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
71 2
|
28天前
|
消息中间件 存储 Java
RocketMQ文件刷盘机制深度解析与Java模拟实现
【11月更文挑战第22天】在现代分布式系统中,消息队列(Message Queue, MQ)作为一种重要的中间件,扮演着连接不同服务、实现异步通信和消息解耦的关键角色。Apache RocketMQ作为一款高性能的分布式消息中间件,广泛应用于实时数据流处理、日志流处理等场景。为了保证消息的可靠性,RocketMQ引入了一种称为“刷盘”的机制,将消息从内存写入到磁盘中,确保消息持久化。本文将从底层原理、业务场景、概念、功能点等方面深入解析RocketMQ的文件刷盘机制,并使用Java模拟实现类似的功能。
40 3
|
1月前
|
XML Android开发 数据格式
Eclipse 创建 XML 文件
Eclipse 创建 XML 文件
25 2
|
1月前
|
Java Maven
maven项目的pom.xml文件常用标签使用介绍
第四届人文,智慧教育与服务管理国际学术会议(HWESM 2025) 2025 4th International Conference on Humanities, Wisdom Education and Service Management
125 8
|
1月前
|
存储
文件太大不能拷贝到U盘怎么办?实用解决方案全解析
当我们试图将一个大文件拷贝到U盘时,却突然跳出提示“对于目标文件系统目标文件过大”。这种情况让人感到迷茫,尤其是在急需备份或传输数据的时候。那么,文件太大为什么会无法拷贝到U盘?又该如何解决?本文将详细分析这背后的原因,并提供几个实用的方法,帮助你顺利将文件传输到U盘。
|
2月前
|
数据安全/隐私保护 流计算 开发者
python知识点100篇系列(18)-解析m3u8文件的下载视频
【10月更文挑战第6天】m3u8是苹果公司推出的一种视频播放标准,采用UTF-8编码,主要用于记录视频的网络地址。HLS(Http Live Streaming)是苹果公司提出的一种基于HTTP的流媒体传输协议,通过m3u8索引文件按序访问ts文件,实现音视频播放。本文介绍了如何通过浏览器找到m3u8文件,解析m3u8文件获取ts文件地址,下载ts文件并解密(如有必要),最后使用ffmpeg合并ts文件为mp4文件。
|
2月前
|
XML Web App开发 JavaScript
XML DOM 解析器
XML DOM 解析器
|
2月前
|
XML Web App开发 JavaScript
XML DOM 解析器
XML DOM 解析器
|
2月前
|
XML Java 数据格式
手动开发-简单的Spring基于XML配置的程序--源码解析
手动开发-简单的Spring基于XML配置的程序--源码解析
86 0

推荐镜像

更多
下一篇
DataWorks