dom解析xml
<?xml version="1.0" encoding="UTF-8"?>
<ShowList>
<Movie>
<name>非常完美</name>
<Poster>perfect</Poster>
<Director>阴萌</Director>
<Actor>范冰冰</Actor>
<Price>100</Price>
<Type>电影</Type>
<Schedule>
<Item>09:00</Item>
<Item>13:00</Item>
</Schedule>
</Movie>
<Movie>
<name>倒塔</name>
<Poster>dota</Poster>
<Director>冰蛙</Director>
<Actor>斧王</Actor>
<Price>50</Price>
<Type>游戏</Type>
<Schedule>
<Item>09:00</Item>
<Item>13:00</Item>
</Schedule>
</Movie>
</ShowList>
这是xml文件
getElementsByTagName()这个方法是得到xml文件里的某个节点
(重要 Node是抽象节点 element是实际的节点 不如movie就是抽象节点 他里面有很多子节点,提到movie也不知道要的是movie里的那个属性, 而 element则是实际的节点提到time,就会在xml文件中找到具体的时间,所以,要找抽象节点的话 就要用Node来接收,实际节点就用element接收)
前三部是固定格式括号里
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
DocumentBuilder db = dbf.newDocumentBuilder();
Document doc = db.parse("src/ShowList.xml");
想得到xml文件里的节点 如果字节不是一个有可能是多个的话,那么就用集合nodelist
从文件里读的信息。所以是文件名。getelementbytagname()方法
Nodelist list=doc。getelementbytagname(“Movie”);
因为是集合,所以要遍历得到你想要的第i个movie节点
for(int i=0;i<list.length();i++){
Node point=list.item(i);
想要得到movie里的其他节点也就是得到movie里的所有子节点
Element element =(Element)point;
比如得到了Schedule的节点,就用下面的方法,但是这个读不出信息,只是把这个节点给了ele
这句话的意思是在movie所有字节点里找到第一个Schedule (如果是item(1)那么就是找到movie所有字节点里的第二个Schedule)
ele就是movie所有字节点里的第一个Schedule
Node ele=element.getelementbytagname("Schedule").item(0);
和上面的point一样因为都是抽象的节点所以用的Node
这个Schedule节点下面还有子节点Item,要得到item就只能先得到他子节点所有的信息 得到所有信息之后才能在这一堆信息里找你所需要的信息
ele2是ele下面所有的item子节点
Element ele2=(Element)ele;
得到所有信息之后需要遍历 ,这句话是找到name这个节点之后得到他的文本值(用方法 .getTextContent();)把得到的值赋值给elename
从所有的item节点中找到第一个name节点赋值给elename
String elename = ele2.getElementsByTagName("name").item(0)
.getTextContent();
得到item这个节点的个数
int length = ele2.getElementsByTagName("Item").getLength();
for (int j = 0; j < 2; j++) {
String elename = ele.getElementsByTagName("name").item(0)
.getTextContent();
String elePoster = ele.getElementsByTagName("Poster").item(0)
.getTextContent();
String eleDirector = ele.getElementsByTagName("Director").item(
0).getTextContent();
String eleActor = ele.getElementsByTagName("Actor").item(0)
.getTextContent();
String elePrice = ele.getElementsByTagName("Price").item(0)
.getTextContent();
String eleType = ele.getElementsByTagName("Type").item(0)
.getTextContent();
String eleItem = ele.getElementsByTagName("Item").item(j)
.getTextContent();
k++;
System.out.println(k + "\t\t" + elename + "\t\t" + elePoster
+ "\t\t" + eleDirector + "\t\t" + eleActor + "\t\t"
+ eleType + "\t\t" + elePrice + "\t\t" + eleItem);
重点 在每一次要找子节点时,首先要做的就是把这个节点的所有子节点全部找到(Element ele = (Element) point;)
之后才能用 ele。getelementbytagname(" ")找到你所需要的字节
找到movie下面的item节点???
首先找到所有的movie节点,(集合) doc是文件
Nodelist movielist=doc。getelementbytagename("movie");
得到第i个movie节点(因为是抽象节点所以用Node)
point为第i个movie节点
Node point=movie。item(i);
获取第i个movie节点的所有子节点
Element ele = (Element) point;
找到movie所有子节点之后要得到movie的第一个子节点(Schedule)
Node ele2=ele。getelementbytagname(“Schedule”)。item(0);
得到Schedule子节点之后就可以得到所有item节点了
ele3为所有的item节点
Element ele3=(Element)ele2;
在逐个得到所有的item节点之前,先要知道有多少个item节点,求出所有item节点的长度
int length=ele3。getelementbytagname(“item”)。length();
for(int i=0;i<length;i++){
在movie的所有子节点里找是否有item
String aaaaaa=ele.getelementbytagname("item").item(i).getTextcontent();
system。out.println(aaaaaa);
}
}
dom解析xml的更多相关文章
- Android之DOM解析XML
一.DOM解析方法介绍 DOM是基于树形结构的节点或信息片段的集合,允许开发人员使用DOM API遍历XML树,检索所需数据.分析该结构通常需要加载整个文档和构造树形结构,然后才可以检索和更新节点信息 ...
- JAVA中使用DOM解析XML文件
XML是一种方便快捷高效的数据保存传输的格式,在JSON广泛使用之前,XML是服务器和客户端之间数据传输的主要方式.因此,需要使用各种方式,解析服务器传送过来的信息,以供使用者查看. JAVA作为一种 ...
- 简单谈谈dom解析xml和html
前言 文件对象模型(Document Object Model,简称DOM),是W3C组织推荐的处理可扩展标志语言的标准编程接口.html,xml都是基于这个模型构造的.这也是一个W3C推出的标准.j ...
- Java从零开始学四十二(DOM解析XML)
一.DOM解析XML xml文件 favorite.xml <?xml version="1.0" encoding="UTF-8" standalone ...
- 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 ...
- python 解析XML python模块xml.dom解析xml实例代码
分享下python中使用模块xml.dom解析xml文件的实例代码,学习下python解析xml文件的方法. 原文转自:http://www.jbxue.com/article/16587.html ...
- Java解析XML文档(简单实例)——dom解析xml
一.前言 用Java解析XML文档,最常用的有两种方法:使用基于事件的XML简单API(Simple API for XML)称为SAX和基于树和节点的文档对象模型(Document Object ...
- xml--通过DOM解析XML
此文章通过3个例子表示DOM方式解析XML的用法. 通过DOM解析XML必须要写的3行代码. step 1: 获得dom解析器工厂(工作的作用是用于创建具体的解析器) step 2:获得具体的dom解 ...
- POPTEST老李分享DOM解析XML之java
POPTEST老李分享DOM解析XML之java Java提供了两种XML解析器:树型解释器DOM(Document Object Model,文档对象模型),和流机制解析器SAX(Simple ...
- 使用DOM解析xml文件
使用DOM解析xml文件 要解析的xml文件如下: <?xml version="1.0" encoding="UTF-8"?> <Langu ...
随机推荐
- HDU 1285 确定比赛名次 拓扑排序模板题
http://acm.hdu.edu.cn/showproblem.php?pid=1285 #include <cstdio> #include <cstdlib> #inc ...
- JavaScript Dom基础
一.DOM查找 1.document.getElementById("id") -功能:返回对拥有指定ID的第一个对象的引用 -返回值:DOM对象 -说明:id为DOM元素上id属 ...
- const用法小结
const与指针 char *const p --> char *(const p) --> 指针常量 char const *p --> char (const *p) --> ...
- [原创][LaTex]汇总博文
0. 简介 为了查找方便,当当当当,灵机一动的设计了这个博文,有了他就能快速的查找一些该话题相关方面的一些博文了,不管是原创.转载.整理,只要是属于我自己整理的LaTex知识,应该都可以在这里找到的. ...
- TOMCAT的安装部署配置(配图解)
TOMCAT的安装部署配置 前提已经成功搭建配置JDK 下载好压缩包后,直接解压至某一目录下,目录中不能包含中文 双击安装文件,出现如下界面 点击[NEXT],出现如下界面 点击[I AGREE],出 ...
- 第七章 consul docker集群
--net=host:运行consul的docker镜像必须带有的参数,因为consul的consensus和gossip协议对于网络的延迟和丢包很敏感,所以引入额外的其他网络类型的层是不可取并且不必 ...
- [题解]UVa 11082 Matrix Decompressing
开始眨眼一看怎么也不像是网络流的一道题,再怎么看也觉得像是搜索.不过虽然这道题数据范围很小,但也不至于搜索也是可以随随便便就可以过的.(不过这道题应该是special judge,因为一题可以多解而且 ...
- Android SVN的配置
关于svn有不错的图文博文,先po一个个人认为很不错的博文:http://ask.android-studio.org/?/article/97 接下来呢呢就是以我个人的思维模式来讲解svn啦: 当然 ...
- ubuntu 15 安装cuda,开启GPU加速
1 首先要开启GPU加速就要安装cuda.安装cuda,首先要安装英伟达的驱动.ubuntu有自带的开源驱动,首先要禁用nouveau.这儿要注意,虚拟机不能安装ubuntu驱动.VMWare下显卡只 ...
- (转)selenuim-webdriver注解之@FindBy、@FindBys、@FindAll的区别
selenium-webdriver中获取页面元素的方式有很多,使用注解获取页面元素是其中一种途径, 方式有3种:@FindBy.@FindBys.@FindAll.下文对3中类型的区别和使用场景进行 ...