<?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的更多相关文章

  1. Android之DOM解析XML

    一.DOM解析方法介绍 DOM是基于树形结构的节点或信息片段的集合,允许开发人员使用DOM API遍历XML树,检索所需数据.分析该结构通常需要加载整个文档和构造树形结构,然后才可以检索和更新节点信息 ...

  2. JAVA中使用DOM解析XML文件

    XML是一种方便快捷高效的数据保存传输的格式,在JSON广泛使用之前,XML是服务器和客户端之间数据传输的主要方式.因此,需要使用各种方式,解析服务器传送过来的信息,以供使用者查看. JAVA作为一种 ...

  3. 简单谈谈dom解析xml和html

    前言 文件对象模型(Document Object Model,简称DOM),是W3C组织推荐的处理可扩展标志语言的标准编程接口.html,xml都是基于这个模型构造的.这也是一个W3C推出的标准.j ...

  4. Java从零开始学四十二(DOM解析XML)

    一.DOM解析XML xml文件 favorite.xml <?xml version="1.0" encoding="UTF-8" standalone ...

  5. 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 ...

  6. python 解析XML python模块xml.dom解析xml实例代码

    分享下python中使用模块xml.dom解析xml文件的实例代码,学习下python解析xml文件的方法. 原文转自:http://www.jbxue.com/article/16587.html ...

  7. Java解析XML文档(简单实例)——dom解析xml

      一.前言 用Java解析XML文档,最常用的有两种方法:使用基于事件的XML简单API(Simple API for XML)称为SAX和基于树和节点的文档对象模型(Document Object ...

  8. xml--通过DOM解析XML

    此文章通过3个例子表示DOM方式解析XML的用法. 通过DOM解析XML必须要写的3行代码. step 1: 获得dom解析器工厂(工作的作用是用于创建具体的解析器) step 2:获得具体的dom解 ...

  9. POPTEST老李分享DOM解析XML之java

    POPTEST老李分享DOM解析XML之java   Java提供了两种XML解析器:树型解释器DOM(Document Object Model,文档对象模型),和流机制解析器SAX(Simple ...

  10. 使用DOM解析xml文件

    使用DOM解析xml文件 要解析的xml文件如下: <?xml version="1.0" encoding="UTF-8"?> <Langu ...

随机推荐

  1. Java中Timer的用法

    现在项目中用到需要定时去检查文件是否更新的功能.timer正好用于此处. 用法很简单,new一个timer,然后写一个timertask的子类即可. 代码如下: package comz.autoup ...

  2. position与z-index的关系

    .simulationgame .gameranking .rankinginfo{ width:140px; margin:0 auto; font-family:Arial, Microsoft ...

  3. sql server 分页存储过程

    ----------------------分页存储过程------------------------------------------------------------------------ ...

  4. JS-小球碰撞反弹

    类似于屏保的一种动画,当小球碰到边框时,发生反弹,并且变化颜色. <!DOCTYPE html><html lang="en"><head>   ...

  5. javascript (js)判断手机号码中国移动、中国联通、中国电信

    我国使用的手机号码为11位,其中各段有不同的编码方向:前3位———网络识别号:第4-7位———地区编码:第8-11位———用户号码. 中国移动134.135.136.137.138.139.150.1 ...

  6. TCP的拥塞控制

    1.引言 计算机网络中的带宽.交换结点中的缓存和处理机等,都是网络的资源.在某段时间,若对网络中某一资源的需求超过了该资源所能提供的可用部分,网络的性能就会变坏.这种情况就叫做拥塞. 拥塞控制就是防止 ...

  7. pip 加速方案

    每当我pip install * 的时候,总是发现速度很慢,通过google,发现还是有方法来解决这种状况的 在~/ 命令下,创建 .pip/pip.conf,我用的是阿里的镜像,速度还是杠杠的 mk ...

  8. Nginx配置upstream实现负载均衡

    如果Nginx没有仅仅只能代理一台服务器的话,那它也不可能像今天这么火,Nginx可以配置代理多台服务器,当一台服务器宕机之后,仍能保持系统可用.具体配置过程如下: 1. 在http节点下,添加ups ...

  9. 关于本地缓存localStorage

    localStorage的优势 1.localStorage拓展了cookie的4K限制 2.localStorage会可以将第一次请求的数据直接存储到本地,这个相当于一个5M大小的针对于前端页面的数 ...

  10. js中typeof与instanceof用法区别

    今天写JS代码,遇到动态生成多个名称相同的input复选按钮 需要判断其是否是数组,用到了if (typeof(document.MapCheckMgr.checkid)!="undefin ...