`

用 DOM 读取一个 XML 文档(二)

XML 
阅读更多
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<学生名册>
	<学生 学号="1">
		<姓名>张三</姓名>
		<!-- haha -->
		<性别>男</性别>
		<年龄>20</年龄>
	</学生>
	<学生 学号="2">
		<姓名>李四</姓名>
		<性别>女</性别>
		<年龄>19</年龄>
	</学生>
	<学生 学号="3">
		<姓名>王五</姓名>
		<性别>男</性别>
		<年龄>21</年龄>
	</学生>
</学生名册>



package com.syh.xml.dom;

import java.io.File;

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.NamedNodeMap;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;

public class DomTest3 {

	public static void main(String[] args) throws Exception {
		
	
	DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance() ;
	
	DocumentBuilder db = dbf.newDocumentBuilder() ;
	
	Document doc = db.parse(new File("student.xml")) ;
	
//	System.out.println(doc.getXmlEncoding()); 
//	System.out.println(doc.getXmlVersion());
//	System.out.println(doc.getXmlStandalone());
	
	//获得 XML 文档的根元素节点
	Element rootEle = doc.getDocumentElement() ;
	System.out.println(rootEle.getTagName());
	
	//这里一定要注意一下空格!因为空格也是属于节点的孩子的组成部分。
	NodeList list = rootEle.getChildNodes() ;
	System.out.println(list.getLength());
	
	for(int i = 0 ; i < list.getLength() ; i ++ ) {
		System.out.println(list.item(i).getNodeName());
	}
	
	System.out.println("----------------节点的类型和节点值-----------------");
	
	for(int i = 0 ; i < list.getLength() ;  i ++) {
		
		Node n = list.item(i) ;
		
		//打印节点的类型和节点值
		System.out.println(n.getNodeType() + " : " + n.getNodeValue());
		
	}
	
	System.out.println("----------------打印所有节点的文本(不包括节点的属性!但是包括空白!因为空白也是属于文本的)-----------------");
	
	for(int i = 0 ; i < list.getLength() ; i ++ ) {
		Node n = list.item(i) ;
		
		System.out.println(n.getTextContent()); 
	}
	
	System.out.println("-----------------拿到属性----------------");
	
	NodeList nodeList = doc.getElementsByTagName("学生") ;
	
	for(int i = 0 ; i < nodeList.getLength() ; i ++) {
		
		NamedNodeMap nnm = nodeList.item(i).getAttributes() ;
		
		String attrName = nnm.item(0).getNodeName() ;
		System.out.print(attrName);
		
		System.out.print(" = ");
		
		String attrValue = nnm.item(0).getNodeValue() ;
		System.out.print(attrValue);
		
		System.out.println();
		
	}
	
	}
}



控制台上出现的效果:

学生名册
7
#text
学生
#text
学生
#text
学生
#text
----------------节点的类型和节点值-----------------
3 : 
	
1 : null
3 : 
	
1 : null
3 : 
	
1 : null
3 : 

----------------打印所有节点的文本(不包括节点的属性!但是包括空白!因为空白也是属于文本的)-----------------

	

		张三
		
		男
		20
	

	

		李四
		女
		19
	

	

		王五
		男
		21
	


-----------------拿到属性----------------
学号 = 1
学号 = 2
学号 = 3



分享到:
评论

相关推荐

    Dom4j解析XML文档.doc

    Dom4j解析XML文档.doc Dom4j解析XML文档.doc Dom4j解析XML文档.doc Dom4j解析XML文档.doc

    【Qt】DOM读取XML文档.rar

    【Qt】DOM读取XML文档.rar

    使用DOM解析XML文档

    文档对象模型 节点和节点树 使用DOM加载XML文档 使用DOM访问、创建和修改节点

    dom4j读写xml文档实例

    NULL 博文链接:https://sxpujs.iteye.com/blog/375485

    利用 dom4j 解析 xml 文档

    自己写的dom4j 解析xml 文档的纤细案例,主要讲解,如何使用dom4j 来读取 或 写入xml 文档。。。

    读写超大类xml文件,使用dom4j读写xml文件的工具类

    基于dom4j的读写xml文件的工具包。封装了dom4j操作xml文档的常和方法。 支持两种读写方法。1:针对小文件的读取整个文档,2:针对大文件的,逐行读取。读到几百M文件毫无压力。

    QT下DOM读/写xml文档

    自己编写的代码经过测试,可以运行!(包含.exe文件)可以为自己编程提供思路参考~;希望对你有帮助!

    dom4j解析xml

    使用dom4j对xml文档进行增删改. 查询就不用说了,使用elements(....)/element(...)/attributeValue()/getText()等方法

    java 的dom的读取xml

    XPath 简介 XPath 是一门在 XML 文档中查找信息的语言。...• XPath 使用路径表达式在 XML 文档中进行导航 • XPath 包含一个标准函数库 • XPath 是 XSLT 中的主要元素 • XPath 是一个 W3C 标准

    如何用vc创建和读取xml文件

    XML DOM对象提供了一个标准的方法来操作存储在XML文档中的信息,DOM应用编程接口(API)用来作为应用程序和XML文档之间的桥梁。  DOM可以认为是一个标准的结构体系用来连接文档和应用程序(也可以是剧本语言)。MSXML...

    dom4j解析xml字符串

    // SAXReader就是一个管道,用一个流的方式,把xml文件读出来 // // SAXReader reader = new SAXReader(); //User.hbm.xml表示你要解析的xml文档 // Document document = reader.read(new File("User.hbm.xml")...

    C#基于DOM方式和流方式读取XML文档的简单示例

    一个简单的C#示例程序,工程中包含两个窗体,分别实现了DOM方式和流方式的XML文件读取及解析,运行环境VS2013.

    利用DOM读写XML

    利用DOM创建DOMDocument对象,生成指定格式的XML文档,亦可对应读取相应文档。

    dom4j 解析(读取) xml 节点数据

    此方法解析xml时,不受xml层级的限制。文件中包含了说明文档,java类,以及所使用到的*.jar。并对代码做了注释让你一目了然……

    php读取xml文件类

    一款php xml读取类,很简单的一个xml分析类了,它可读取指它xml文档,并且输出或取得指定节点的xml数据,本xml类代码是利用了php domdocument来解析xml文档。

    dom4j解析xml.txt

    java dom4j 解析xml文档 使用java操作xml 例如创建 读取 删除 等等

    dom和sax结合解析xml文档

    分析如何结合使用dom技术和sax技术解析xml文件,实现既可以读取大文档xml又可以实现简单操作xml文件

    zTree树型菜单+Dom4j解析XML+struts2+spring整合_完整树型菜单权限管理案例(附源代码+API学习文档)

    前台页面展示用zTree插件,后台数据用XML保存,利用Dom4j进行解析,涉及到了对XML的增、删、改等等特别需求的技术,并用struts2+spring进行整合项目,源代码中有非常完整的注释,导入myEclipse部署运行,即可从...

Global site tag (gtag.js) - Google Analytics