JAVA读取XML文件并解析获取元素、属性值、子元素信息
JAVA读取XML文件并解析获取元素、属性值、子元素信息
关键字
XML读取 InputStream DocumentBuilderFactory Element Node
前言
正文(直接上源码)
XML文件
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"> <bean name="HelloWorld" class="com.huishe.HelloWord">
<property name="textone" value="Hello World!"></property>
<property name="texttwo" value="Hello SUN!"></property>
</bean> </beans>
XMLParse解析源码
package com.huishe.testOfSpring; import java.io.FileInputStream;
import java.io.InputStream; import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory; import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList; public class XMLParse { public static void main(String[] args) throws Exception {
//1-获取XML-IO流
InputStream xmlInputStream = getXmlInputStream("xml/tinyioc.xml");
//2-解析XML-IO流 ,获取Document 对象,以及Document对象 的根节点
Element rootElement = getRootElementFromIs(xmlInputStream);
//3~5-从根元素解析得到元素
parseElementFromRoot(rootElement); //控制台输出:
//name == HelloWorld
//className == com.huishe.HelloWord
//propertyEle: name == textone
//propertyEle: value == Hello World!
//propertyEle: name == texttwo
//propertyEle: value == Hello SUN!
} //1-获取XML-IO流
private static InputStream getXmlInputStream(String xmlPath){
InputStream inputStream = null;
try {
//1-把要解析的 XML 文档转化为输入流,以便 DOM 解析器解析它
inputStream= new FileInputStream(xmlPath);
} catch (Exception e) {
e.printStackTrace();
}
return inputStream;
}
//2-解析XML-IO流 ,获取Document 对象,以及Document对象 的根节点
private static Element getRootElementFromIs(InputStream inputStream) throws Exception {
if(inputStream == null){
return null;
}
/*
* javax.xml.parsers 包中的DocumentBuilderFactory用于创建DOM模式的解析器对象 ,
* DocumentBuilderFactory是一个抽象工厂类,它不能直接实例化,但该类提供了一个newInstance方法 ,
* 这个方法会根据本地平台默认安装的解析器,自动创建一个工厂的对象并返回。
*/
//2-调用 DocumentBuilderFactory.newInstance() 方法得到创建 DOM 解析器的工厂
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
//3-调用工厂对象的 newDocumentBuilder方法得到 DOM 解析器对象。
DocumentBuilder docBuilder = factory.newDocumentBuilder();
//4-调用 DOM 解析器对象的 parse() 方法解析 XML 文档,得到代表整个文档的 Document 对象,进行可以利用DOM特性对整个XML文档进行操作了。
Document doc = docBuilder.parse(inputStream);
//5-得到 XML 文档的根节点
Element root =doc.getDocumentElement();
//6-关闭流
if(inputStream != null){
inputStream.close();
}
return root;
} //3-从根元素解析得到元素
private static void parseElementFromRoot(Element root) {
NodeList nl = root.getChildNodes();
for (int i = 0; i < nl.getLength(); i++) {
Node node = nl.item(i);
if (node instanceof Element) {
Element ele = (Element) node;
//4-从元素解析得到属性值
getDataFromElement(ele);
//5-从元素解析特定子元素并解析(以property为例)
getCertainElementFromParentElement(ele);
}
}
} //4-从元素解析得到属性值
private static void getDataFromElement(Element ele) {
String name = ele.getAttribute("name");//根据属性名称读取属性值
System.out.println("name == " + name);
String className = ele.getAttribute("class");
System.out.println("className == " + className);
}
//5-从元素解析特定子元素并解析(以property为例)
private static void getCertainElementFromParentElement(Element ele) {
NodeList propertyEleList = ele.getElementsByTagName("property");//根据标签名称获取标签元素列表
for (int i = 0; i < propertyEleList.getLength(); i++) {
Node node = propertyEleList.item(i);
if (node instanceof Element) {
Element propertyEle = (Element) node;
String name = propertyEle.getAttribute("name");
System.out.println("propertyEle: name == " + name);
String value = propertyEle.getAttribute("value");
System.out.println("propertyEle: value == " + value);
}
} } }
总结
读取XML配置涉及到IO、DocumentBuilderFactory、Node等概念,这里只使用,不具体分析
参考文献
1- https://blog.csdn.net/hua1017177499/article/details/78985166
JAVA读取XML文件并解析获取元素、属性值、子元素信息的更多相关文章
- java 读取XML文件作为配置文件
首先,贴上自己的实例: XML文件:NewFile.xml(该文件与src目录同级) <?xml version="1.0" encoding="UTF-8&quo ...
- java读取xml文件报“org.xml.sax.SAXParseException: Premature end of file” .
背景:java读取xml文件,xml文件内容只有“<?xml version="1.0" encoding="UTF-8"?>”一行 java读取该 ...
- java读取XML文件的四种方式
java读取XML文件的四种方式 Xml代码 <?xml version="1.0" encoding="GB2312"?> <RESULT& ...
- java读取 xml文件
java读取xml文件的四种方法 转自https://www.cnblogs.com/lingyao/p/5708929.html Xml代码 1 <?xml version="1. ...
- 通过Java读取xml文件内容
读取XML中的内容就需要对XML进行解析,目前对XML进行解析的方法分为四种: 下面解析的方法是DOM4J,需要下载jar包dom4j:https://dom4j.github.io/ package ...
- 用java操作XML文件(DOM解析方式)
XML 可扩展标记语言(Extensible Markup Language),是独立于软件和硬件的传输工具. XML的作用: (1)用作配置文件 (2)简化数据共享 (3)简化数据传输 XML DO ...
- JAVA读取XML文件数据
XML文档内容如下: <?xml version="1.0" encoding="UTF-8"?> <root> <field t ...
- java读取XML文件,及封装XML字符串
package com.yyl.text; import java.io.FileInputStream; import java.util.ArrayList; import org.junit.T ...
- 【Java】XML文件的解析
import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import ja ...
随机推荐
- UI5-学习篇-14-基于BSP应用部署Fiori Launchpad
1.UI5应用发布前端服务器 UI5-学习篇-10-本地UI5应用部署到SAP前端服务器 2.登录Fiori https://XXXXXX:50000/sap/bc/ui5_ui5/sap/arsrv ...
- Swap Nodes in Pairs LeetCode题解
做完这个题目,感觉LeetCode的题目出的真好... 这种题,如果让我在面试时候纸上写代码,肯定会挂的. 我昨天晚上看的题目,昨天脑子是懵的,放下了.今天早上来做. 一开始做,提交,果然错了.写的代 ...
- MemSQL 架构初探(转)
MemSQL 自称是最快的内存数据库.目前已发布了2.5版本. MemSQL 具有以下特点 1 高效的并行,尤其是分布式的MemSQL. 2 高效的并发,采用lock-free的内存数据结构skip ...
- 从初始化列表和构造函数谈C++的初始化机制
来源:http://blog.csdn.net/theprinceofelf/article/details/20057359 前段时间被人问及“初始化列表和构造有什么区别?”我竟一时语塞,只好回头 ...
- python小实例一:简单爬虫
本文所谓的爬虫就是通过本地远程访问url,然后将url的读成源代码形式,然后对源代码进行解析,获取自己需要的数据,相当于简单数据挖掘.本文实现的是将一个网页的图片爬出保存到本地的过程,例子很简单,用的 ...
- HttpURLConnection类的使用
此类以获取天气的一个api地址为例: package javaexcjs; import java.io.BufferedReader; import java.io.OutputStreamWrit ...
- django select_related()和反射结合
对于有外键关联的表,select_related()会自动进行多变关联; ret = models.UserInfo.objects.all().select_related() print ret. ...
- 吴裕雄 python 熵权法确定特征权重
一.熵权法介绍 熵最先由申农引入信息论,目前已经在工程技术.社会经济等领域得到了非常广泛的应用. 熵权法的基本思路是根据各个特征和它对应的值的变异性的大小来确定客观权重. 一般来说,若某个特征的信息熵 ...
- centos 安装python3.6
环境准备 yum install openssl-devel bzip2-devel expat-devel gdbm-devel readline-devel sqlite-devel 首先去官网下 ...
- 求1到n,n个整数的全排列
package com.dong.harder; public class AllArrays { public static void main(String[] args) { // TODO A ...