---------------siwuxie095

工程名:TestReadXML

包名:com.siwuxie095.xml

类名:ReadXML.java

打开资源管理器,在工程 TestReadXML 文件夹下,放入

一个 XML 文件:languages.xml

languages.xml 的内容:

工程结构目录如下:

代码:

package com.siwuxie095.xml;

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.Node;

import org.w3c.dom.NodeList;

import org.xml.sax.SAXException;

public class ReadXML {

/**

*

* 使用Java语言实现XML数据的解析

* DOM方式解析

*

* @param args

*/

public static void main(String[] args) {

//创建一个 DocumentBuilderFactory 对象,通过类调用静态方法获取一个新的实例

DocumentBuilderFactory factory=DocumentBuilderFactory.newInstance();

try {

//通过对象 factory 调用 newDocumentBuilder() 方法,创建一个新的 DocumentBuilder

//返回值是 DocumentBuilder 类型,创建对象,接收返回值

//有异常抛出,用 try catch 捕获

DocumentBuilder builder=factory.newDocumentBuilder();

//使用 builder 来创建真正的XML文档

//使用 builder 的 parse()方法,传入文件对象,返回 Document 类型

//(这里是匿名对象,使用相对路径)

//创建一个 Document 对象来接收返回值

//(注意:使用 org.w3c.dom 包中的 Document 类)

//有异常抛出,用 try catch 捕获

Document document=builder.parse(new File("languages.xml"));

//文档创建完成后,开始读取

//

//先读取根元素:languages,创建一个 Element 对象

//(注意:使用 org.w3c.dom 包中的 Element 类)

//getDocumentElement() 获取文档元素即文档根元素

Element root=document.getDocumentElement();

//获取根元素的属性值

System.out.println("category="+root.getAttribute("category"));

//接着读取根元素的子集元素:lan

//getElementsByTagName() 的返回值是 NodeList 类型,即一个集合

//创建一个 NodeList对象接收返回值

NodeList list=root.getElementsByTagName("lan");

//创建for循环,循环打印 lan 内部的值

//循环次数使用 NodeList 的 getLength() 方法

for (int i = 0; i < list.getLength(); i++) {

//创建一个 Element,调用list的item()方法,

//传入下标i,按照循环次数获取list中的内容

//但item()的返回值是Node类型,是Element的父类

//父类转子类,需要进行强制转换

Element lan=(Element) list.item(i);

//将 for循环中的元素分隔开

System.out.println("-------------");

//获取属性值

System.out.println("id="+lan.getAttribute("id"));

//获取 lan 中的两个子节点:

//name 和 ide,是两个不同的 TagName

//

//不建议使用下面的方法:

//可以使用getElementsByTagName(),但弊端是返回的是一个集合

//两个节点即两个集合,还要从两个集合中分别取第一个值

//(因为已知一个节点只有一项)

Element name=(Element) lan.getElementsByTagName("name").item(0);

//获取当前节点中的文本内容(字符型数据)

//System.out.println("name="+name.getTextContent());

//获取 lan 中的两个子节点,因为lan下的子节点同级,建议使用:

//getChildNodes()方法,获取lan下的所有的子节点,

//返回值是 NodeList 类型,创建对象接收返回值

NodeList clist=lan.getChildNodes();

for (int j = 0; j < clist.getLength(); j++) {

//这里和上面不一样,如果创建Element对象并强转,会报错:类型转换错误

Node c=clist.item(j);

//如果当前的节点是Element对象,才输出

//如果不判断,当前的API在打印时会把每一行后面的空白+回车、缩进符

//当做两个新节点,即获取节点时并不是只获取可见的节点,

//对于不可见的数据,同样要作为一个节点读取

if (c instanceof Element) {

//获取 name、ide 节点

System.out.println(c.getNodeName()+"="+c.getTextContent());

}

}

}

} catch (ParserConfigurationException e) {

e.printStackTrace();

} catch (SAXException e) {

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}

}

}

运行一览:

加了 if (c instanceof Element) 判断:

不加 if (c instanceof Element) 判断:

【made by siwuxie095】

使用Java读取XML数据的更多相关文章

  1. Java读取xml数据

    xml中的代码 <?xml version="1.0" encoding="UTF-8"?> <books id="aaa" ...

  2. Java中XML数据

    Java中XML数据 XML解析——Java中XML的四种解析方式 XML是一种通用的数据交换格式,它的平台无关性.语言无关性.系统无关性.给数据集成与交互带来了极大的方便.XML在不同的语言环境中解 ...

  3. wcf序列化大对象时报错:读取 XML 数据时,超出最大

    错误为: 访问服务异常:格式化程序尝试对消息反序列化时引发异常: 尝试对参数 http://tempuri.org/ 进行反序列化时出 错: request.InnerException 消息是“反序 ...

  4. java 读取XML文件作为配置文件

    首先,贴上自己的实例: XML文件:NewFile.xml(该文件与src目录同级) <?xml version="1.0" encoding="UTF-8&quo ...

  5. java读取xml文件报“org.xml.sax.SAXParseException: Premature end of file” .

    背景:java读取xml文件,xml文件内容只有“<?xml version="1.0" encoding="UTF-8"?>”一行 java读取该 ...

  6. InnerException 消息是“反序列化对象 属于类型 *** 时出现错误。读取 XML 数据时,超出最大字符串内容长度配额 (8192)。(注意细节)

    WEB站点在调用我们WCF服务的时候,只要传入的参数过长,就报如下错误: 格式化程序尝试对消息反序列化时引发异常: 尝试对参数 http://tempuri.org/ 进行反序列化时出错: formD ...

  7. java读取XML文件的四种方式

    java读取XML文件的四种方式 Xml代码 <?xml version="1.0" encoding="GB2312"?> <RESULT& ...

  8. JAVA读取XML文件并解析获取元素、属性值、子元素信息

    JAVA读取XML文件并解析获取元素.属性值.子元素信息 关键字 XML读取  InputStream   DocumentBuilderFactory   Element     Node 前言 最 ...

  9. Web Service 或 WCF调用时读取 XML 数据时,超出最大字符串内容长度配额(8192)解决方法

    1.调用服务时服务 当我们使用 Web Service 或 WCF 服务时,常把读取的数据转化为string类型(xml格式),当数据量达到一 定数量时,会出现以下异常: 错误:格式化程序尝试对消息反 ...

随机推荐

  1. C++11 Lambda表达式(匿名函数)

    http://www.cnblogs.com/RainyBear/p/5733399.html http://blog.163.com/lvan100@yeah/blog/static/6811721 ...

  2. 自己搭建MVC时遇到的一些问题及解决办法

    错误1 The view 'Index' or its master was not found or no view engine supports the searched locations. ...

  3. 【MFC】VC界面绘制双缓存

    VC界面绘制双缓存 转载请注明原文网址: http://www.cnblogs.com/xianyunhe/archive/2011/11/20/2255811.html 1.闪屏的问题在GDI的绘图 ...

  4. python学习之aop装饰模式

    实际开发过程当中可能要对某些方法或者流程做出改进,添加监控,添加日志记录等所以我们要去改动已有的代码,自己的或者别人的,但改动后测试不周会引发不可控的异常,aop 模式解决了这类问题引发重复代码大量积 ...

  5. 剑指Offer面试题:13.合并两个排序的链表

    一 题目:合并两个排序的链表 题目:输入两个递增排序的链表,合并这两个链表并使新链表中的结点仍然是按照递增排序的.例如输入下图中的链表1和链表2,则合并之后的升序链表如链表3所示. 二 代码实现 te ...

  6. SQLmap是一款用来检测与利用SQL漏洞的注入神器。

    sqlmap 重要参考 http://www.kali.org.cn/forum-75-1.html SQLmap是一款用来检测与利用SQL漏洞的注入神器.开源的自动化SQL注入工具,由Python写 ...

  7. Django-rest-framework多条件查询/分页/多表Json

    http://www.mamicode.com/info-detail-1648765.html

  8. Hadoop(二)自定义输出

    Hadoop提供了较为丰富的数据输入输出格式,可以满足很多的设计实现,但是在某些时候需要自定义输入输出格式. 数据的输入格式用于描述MapReduce作业的数据输入规范,MapReduce框架依靠 数 ...

  9. 调试VBA程序常用方法

    在中断模式下(ctrl+Break键),可以做: 1.执行    工具----选项----编辑器----勾选“自动显示数据提示” 则当用鼠标悬停在变量或表达式上时,会出现提示窗口,显示其名称和值! 2 ...

  10. aspupload ,在winows server 2008 下无法使用

    aspupload ,在winows server 2008 下无法使用.求助解决办法 2014-01-12 13:31 goolean | 浏览 775 次 操作系统 aspupload64位,安装 ...