POPTEST老李分享DOM解析XML之java
POPTEST老李分享DOM解析XML之java
Java提供了两种XML解析器:树型解释器DOM(Document Object Model,文档对象模型),和流机制解析器SAX(Simple API for XML,XML简单API)。DOM可以将XML转换为树结构。
XML文档内容如下:
文件名:NameList.xml,文件路径:C:\Users\Tsybius\Desktop\NameList.xml
<?
xml
version
=
"1.0"
encoding
=
"UTF-8"
?>
<
root
>
<
list1
>
<
person
id
=
"101"
name
=
"Tsybius"
remark
=
"1"
/>
<
person
id
=
"102"
name
=
"Galatea"
remark
=
"2"
/>
<
person
id
=
"103"
name
=
"Quintus"
remark
=
"3"
/>
<
person
id
=
"104"
name
=
"Atia"
remark
=
"4"
/>
<
person
id
=
"105"
name
=
"Justitia"
remark
=
"5"
/>
</
list1
>
<
list2
>
<
person
id
=
"201"
name
=
"Zhang"
remark
=
"a"
/>
<
person
id
=
"202"
name
=
"Wang"
remark
=
"b"
/>
<
person
id
=
"203"
name
=
"Li"
remark
=
"c"
/>
<
person
id
=
"204"
name
=
"Zhao"
remark
=
"d"
/>
<
person
id
=
"205"
name
=
"Liu"
remark
=
"e"
/>
</
list2
>
<
text
>TEXT</
text
>
</
root
>
package
XmlDomTest;
import
java.io.File;
import
java.io.IOException;
import
javax.xml.parsers.DocumentBuilder;
import
javax.xml.parsers.DocumentBuilderFactory;
import
javax.xml.parsers.ParserConfigurationException;
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.w3c.dom.Text;
import
org.xml.sax.SAXException;
/**
* 使用DOM解析XML
* @author Tsybius
*
*/
public
class
XmlDomTest {
/**
* 使用DOM解析XML
* @param args
*/
public
static
void
main(String[] args) {
try
{
String filePath =
"C:\\Users\\Tsybius\\Desktop\\NameList.xml"
;
File f =
new
File(filePath);
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
Document doc = builder.parse(f);
//遍历节点方式1
Element root = doc.getDocumentElement();
System.out.println(
"根节点名:"
+ root.getNodeName());
NodeList children = root.getChildNodes();
for
(
int
i =
0
; i < children.getLength(); i++) {
Node child = children.item(i);
if
(child
instanceof
Element) {
Element childElement = (Element)child;
System.out.println(
"节点名:"
+ childElement.getNodeName());
if
(childElement.getNodeName().equals(
"list1"
)) {
//list1
//遍历节点方式2
//获取指定属性
for
(Node list1Node = childElement.getFirstChild();
list1Node !=
null
;
list1Node = list1Node.getNextSibling()) {
if
(list1Node
instanceof
Element) {
Element list1Element = (Element)list1Node;
System.out.print(
"person:"
);
System.out.print(
"id="
+ list1Element.getAttribute(
"id"
) +
";"
);
System.out.print(
"name="
+ list1Element.getAttribute(
"name"
) +
";"
);
System.out.print(
"remark="
+ list1Element.getAttribute(
"remark"
) +
";"
);
System.out.println();
}
}
}
else
if
(childElement.getNodeName().equals(
"list2"
)) {
//list2
//遍历节点方式2
//遍历所有属性
for
(Node list2Node = childElement.getFirstChild();
list2Node !=
null
;
list2Node = list2Node.getNextSibling()) {
if
(!(list2Node
instanceof
Element)) {
continue
;
}
NamedNodeMap attributes = ((Element)list2Node).getAttributes();
System.out.print(
"person:"
);
for
(
int
counter =
0
; counter < attributes.getLength(); counter++) {
Node attribute = attributes.item(counter);
if
(attribute ==
null
) {
continue
;
}
String name = attribute.getNodeName();
String value = attribute.getNodeValue();
System.out.print(name +
"="
+ value +
";"
);
}
System.out.println();
}
}
else
if
(childElement.getNodeName().equals(
"text"
)) {
//text
//获取文本值
Text textNode = (Text)childElement.getFirstChild();
String text = textNode.getData().trim();
System.out.println(
"text:"
+ text);
}
}
}
}
catch
(ParserConfigurationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
catch
(SAXException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
catch
(IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
catch
(Exception e) {
e.printStackTrace();
}
}
}
根节点名:root
节点名:list1
person:id=101;name=Tsybius;remark=1;
person:id=102;name=Galatea;remark=2;
person:id=103;name=Quintus;remark=3;
person:id=104;name=Atia;remark=4;
person:id=105;name=Justitia;remark=5;
节点名:list2
person:id=201;name=Zhang;remark=a;
person:id=202;name=Wang;remark=b;
person:id=203;name=Li;remark=c;
person:id=204;name=Zhao;remark=d;
person:id=205;name=Liu;remark=e;
节点名:text
text:TEXT
POPTEST老李分享DOM解析XML之java的更多相关文章
- JAVA中使用DOM解析XML文件
XML是一种方便快捷高效的数据保存传输的格式,在JSON广泛使用之前,XML是服务器和客户端之间数据传输的主要方式.因此,需要使用各种方式,解析服务器传送过来的信息,以供使用者查看. JAVA作为一种 ...
- Java从零开始学四十二(DOM解析XML)
一.DOM解析XML xml文件 favorite.xml <?xml version="1.0" encoding="UTF-8" standalone ...
- Java解析XML文档(简单实例)——dom解析xml
一.前言 用Java解析XML文档,最常用的有两种方法:使用基于事件的XML简单API(Simple API for XML)称为SAX和基于树和节点的文档对象模型(Document Object ...
- Java解析XML文档——dom解析xml
一.前言 用Java解析XML文档,最常用的有两种方法:使用基于事件的XML简单API(Simple API for XML)称为SAX和基于树和节点的文档对象模型(Document Object M ...
- 精讲 org.w3c.dom(java dom)解析XML文档
org.w3c.dom(java dom)解析XML文档 位于org.w3c.dom操作XML会比较简单,就是将XML看做是一颗树,DOM就是对这颗树的一个数据结构的描述,但对大型XML文件效果可能会 ...
- 老李分享:导出xml报告到手机
老李分享:导出xml报告到手机 poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标.如果对课程感兴趣,请大家咨询qq:908821 ...
- Android之DOM解析XML
一.DOM解析方法介绍 DOM是基于树形结构的节点或信息片段的集合,允许开发人员使用DOM API遍历XML树,检索所需数据.分析该结构通常需要加载整个文档和构造树形结构,然后才可以检索和更新节点信息 ...
- 简单谈谈dom解析xml和html
前言 文件对象模型(Document Object Model,简称DOM),是W3C组织推荐的处理可扩展标志语言的标准编程接口.html,xml都是基于这个模型构造的.这也是一个W3C推出的标准.j ...
- xml语法、DTD约束xml、Schema约束xml、DOM解析xml
今日大纲 1.什么是xml.xml的作用 2.xml的语法 3.DTD约束xml 4.Schema约束xml 5.DOM解析xml 1.什么是xml.xml的作用 1.1.xml介绍 在前面学习的ht ...
随机推荐
- html5中的meta标签
1. <meta http-equiv="X-UA-Compatible" content="IE=edge" /> IE=edge告诉IE使用最新 ...
- js设计模式--策略模式
策略模式: 定义了一系列的算法,把他们封装起来,是它们之间可以互相替换,此模式不会影响到使用算法的客户. 回忆下jquery里的animate方法: $( div ).animate( {" ...
- VMware WorkStation9.0虚拟机如何运行WINPE
VMware WorkStation9.0虚拟机如何运行WINPE...我们在使用VMware的过程中,有些时候需要让VMware来运行WINPE系统,比如在使用VMware进行系统封装的过程中,其中 ...
- html中DTD
DTD 是一套关于标记符的语法规则.它是XML1.0版规格得一部分,是html文件的验证机制,属于html文件组成的一部分. DTD:三种文档类型:Strict(严格的).Transitional(过 ...
- maven项目发布不成功的问题
MyEclipes 里面有好多的项目,有些项目是插件有些是组件, 就是有些项目是被依赖的项目,有些事项目的主体,被依赖的项目需要打成jar 包放在maven的中央仓库里面,也是所说的maven的 ...
- linux网络编程1 最简单的socket编程
下面是socket编程的服务器端 先看一个图,1 #include<stdio.h> #include<stdlib.h> #include<string.h> # ...
- nginx在CentOs下的安装及配置
前言: 先介绍一下nginx: Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like 协议下发行.其特点是占有内存少,并发能力强, ...
- Objective-C日记-Bounds和Frame
今天在学习有关UIView时,关于Bounds和Frame的问题困扰多时,今日研究了一翻,有所收获,遂记之. 一.问题来源 网上有关bounds和frames的比较的文章主要就是一篇:http://b ...
- 1593: [Usaco2008 Feb]Hotel 旅馆
1593: [Usaco2008 Feb]Hotel 旅馆 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 391 Solved: 228[Submit ...
- 3360: [Usaco2004 Jan]算二十四
3360: [Usaco2004 Jan]算二十四 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 6 Solved: 6[Submit][Statu ...