<?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. js对象的继承以及公有私有属性的定义和读写

    最近想写一些js工具,有些方面需要用到面向对象的方法,比如继承父类属性和方法.通过私有化隐藏某些对象的属性等,因为没有系统的学习js,所以不知道怎么做,觉得很伤脑筋. 今天受到技术群里朋友的提示,并查 ...

  2. C语言获取时间

    转载:http://www.cnblogs.com/fzhe/archive/2012/11/06/2757858.html C语言获取系统时间的几种方式   C语言中如何获取时间?精度如何? 1 使 ...

  3. Linux中多线程信号的处理

    1. 博文:Linux多线程中使用信号-1  http://blog.csdn.net/qq276592716/article/details/7325250 2. 博文:Linux多线程信号总结  ...

  4. NAT技术

    该文摘自百度百科"NAT"中的一部分 NAT(Network Address Translation,网络地址转换)是1994年提出的.当在专用网内部的一些主机本来已经分配到了本地 ...

  5. 黑科技项目:英雄无敌III Mod <<Fallen Angel>>介绍

    英雄无敌三简介(Heroes of Might and Magic III) 英3是1999年由New World Computing在Windows平台上开发的回合制策略魔幻游戏,其出版商是3DO. ...

  6. ASP.NET中的Session怎么正确使用

    Session对象用于存储从一个用户开始访问某个特定的aspx的页面起,到用户离开为止,特定的用户会话所需要的信息.用户在应用程序的页面切换时,Session对象的变量不会被清除. 对于一个Web应用 ...

  7. 取出Object对象里面的字段,

    Type s = result.GetType(); bool f = (bool)s.GetField("Succeed").GetValue(result);//Succeed ...

  8. Modern C++ CHAPTER 2(读书笔记)

    CHAPTER 2 Recipe 2-1. Initializing Variables Recipe 2-2. Initializing Objects with Initializer Lists ...

  9. 搭建高可用mongodb集群(一)——配置mongodb

    在大数据的时代,传统的关系型数据库要能更高的服务必须要解决高并发读写.海量数据高效存储.高可扩展性和高可用性这些难题.不过就是因为这些问题Nosql诞生了. NOSQL有这些优势: 大数据量,可以通过 ...

  10. ADV数字的剪切

    #include <iostream> using namespace std; #define SIZE 9 #define MAXLEN 6 int data[SIZE][MAXLEN ...