---------------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. (二)canvas边框问题

    lineWidth 设置边框的大小 fillStyle 设置div的颜色 strokeStyle 设置边框的颜色 注: 边框在不设置的情况下默认为1px 黑色,但是x,y轴的距离是以图形的正中心为原始 ...

  2. 互联网公司面试必问的mysql题目(上)

    又到了招聘的旺季,被要求准备些社招.校招的题库.(如果你是应届生,尤其是东北的某大学,绝对福利哦) 介绍:MySQL是一个关系型数据库管理系统,目前属于 Oracle 旗下产品.虽然单机性能比不上or ...

  3. SqlServer 数据库读写分离【转】

    1. 实现原理:读写分离简单的说是把对数据库读和写的操作分开对应不同的数据库服务器,这样能有效地减轻数据库压力,也能减轻io压力.主数据库提供写操作,从数据库提供读操作,其实在很多系统中,主要是读的操 ...

  4. raw_in_fields

    在admin后台类中加入raw_id_fields(只适用于外键)后,会显示外键的详细信息

  5. 为什么 I2C(IIC)需要上拉电阻

    源鑫问: I2C时钟线和数据线为什么要接上拉电阻? 因为 I2C 的 IO 是开漏的,所以需要上拉电阻. 延伸: 之前 hippo曾经说过有人将 IO 设置为 PP,可能会烧 IO. 之前以为 I2C ...

  6. MDK中STM32使用Printf函数详细解析【转载】

    在用MDK调试STM32板子串口时,为了方便串口调试,调用了printf()函数,用Keil仿真是,串口不能正确的输出,软件仿真时,总是卡在那 里.有点纳闷,然后调用USART_SendData()函 ...

  7. 关于Gateway

    为什么要有gateway?就是因为如果没有,很多的功能需要在在每个微服务中都实现,这样成本很高.

  8. jquery调用spring mvc接口返回字符串匹配

    背景:有个增删改页面,用jquery祭出ajax异步调用接口,spring mvc响应对象是个json字符串,jquery根据响应结果判断,如果删除成功给出提示.那么问题来了,接口里响应的字符串怎么匹 ...

  9. git忽略一些提交上传的文件

    在项目开发的过程中有两种文件是不需要提交的. 1.一些很重要的配置文件 包括服务器地址 账号密码 数据库密码 公私钥等等 2.一些由于开发和沙箱环境和线上环境的差异 不能使用同一个时候 需要同一个文件 ...

  10. 【转】 Pro Android学习笔记(九三):AsyncTask(2):小例子

    目录(?)[-] 继承AsyncTask UI操作接口 使用AsyncTask 文章转载只能用于非商业性质,且不能带有虚拟货币.积分.注册等附加条件.转载须注明出处:http://blog.csdn. ...