---------------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. (十)java条件结构

    条件结构 if(条件表达式) {}: if(条件表达式){} else {}; if(条件表达式){} else if(条件表达式) {} else if(条件表达式){} ...... else{} ...

  2. 机器学习(八)—Apriori算法

    摘要:本文对Apriori算法进行了简单介绍,并通过Python进行实现,进而结合UCI数据库中的肋形蘑菇数据集对算法进行验证. “啤酒与尿布”的例子相信很多人都听说过吧,故事是这样的:在一家超市中, ...

  3. ActionContext介绍(在Struts2中)

    一种属性的有序序列,它们为驻留在环境内的对象定义环境.在对象的激活过程中创建上下文,对象被配置为要求某些自动服务,如同步.事务.实时激活.安全性等等.多个对象可以存留在一个上下文内.也有根据上下文理解 ...

  4. Django的CSRF机制

    原文链接:http://www.cnblogs.com/lins05/archive/2012/12/02/2797996.html 必须有的是: 1.每次初始化一个项目时,都能看到django.mi ...

  5. 给System.Timer类的Elapsed事件加锁

    背景: 最近在做一个项目,程序是命令行程序,在主程序中开一个线程,这个线程用到了System.Timer类的Elapsed事件,根据指定时间间隔循环去查询数据库,找符合条件的记录,把记录组织成xml对 ...

  6. Source Insight中文字体设置

    Source Insight是一个面向项目开发的程序编辑器和代码阅读工具,它拥有内置的对C/C++, C#和Java等程序的分析,分析你的源代 码并在你工作的同时动态维护它自己的符号数据库,并自动为你 ...

  7. cvc-complex-type.2.4.a: Invalid content was found starting with element 'async-supported'

    <servlet> <servlet-name>springMVC</servlet-name> <servlet-class>org.springfr ...

  8. 事务之二:spring事务(事务管理方式,事务5隔离级别,7个事务传播行为,spring事务回滚条件)

    事物管理对于企业应用来说是至关重要的,好使出现异常情况,它也可以保证数据的一致性. spring支持编程式事务管理和声明式事务管理两种方式. 编程式事务管理使用TransactionTemplate或 ...

  9. zk 06之:ZooKeeper命令、命令行工具及简单操作

    常用命令ZooKeeper 支持某些特定的四字命令字母与其的交互.它们大多是查询命令,用来获取 ZooKeeper 服务的当前状态及相关信息.用户在客户端可以通过 telnet 或 nc 向 ZooK ...

  10. 微信官方jssdk Demo

    1.html部分 <!DOCTYPE html> <!-- saved from url=(0028){sh:$selfUrl} --> <html><hea ...