<?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
【Qt】DOM读取XML文档.rar
文档对象模型 节点和节点树 使用DOM加载XML文档 使用DOM访问、创建和修改节点
NULL 博文链接:https://sxpujs.iteye.com/blog/375485
自己写的dom4j 解析xml 文档的纤细案例,主要讲解,如何使用dom4j 来读取 或 写入xml 文档。。。
基于dom4j的读写xml文件的工具包。封装了dom4j操作xml文档的常和方法。 支持两种读写方法。1:针对小文件的读取整个文档,2:针对大文件的,逐行读取。读到几百M文件毫无压力。
自己编写的代码经过测试,可以运行!(包含.exe文件)可以为自己编程提供思路参考~;希望对你有帮助!
使用dom4j对xml文档进行增删改. 查询就不用说了,使用elements(....)/element(...)/attributeValue()/getText()等方法
XPath 简介 XPath 是一门在 XML 文档中查找信息的语言。...• XPath 使用路径表达式在 XML 文档中进行导航 • XPath 包含一个标准函数库 • XPath 是 XSLT 中的主要元素 • XPath 是一个 W3C 标准
XML DOM对象提供了一个标准的方法来操作存储在XML文档中的信息,DOM应用编程接口(API)用来作为应用程序和XML文档之间的桥梁。 DOM可以认为是一个标准的结构体系用来连接文档和应用程序(也可以是剧本语言)。MSXML...
// SAXReader就是一个管道,用一个流的方式,把xml文件读出来 // // SAXReader reader = new SAXReader(); //User.hbm.xml表示你要解析的xml文档 // Document document = reader.read(new File("User.hbm.xml")...
一个简单的C#示例程序,工程中包含两个窗体,分别实现了DOM方式和流方式的XML文件读取及解析,运行环境VS2013.
利用DOM创建DOMDocument对象,生成指定格式的XML文档,亦可对应读取相应文档。
此方法解析xml时,不受xml层级的限制。文件中包含了说明文档,java类,以及所使用到的*.jar。并对代码做了注释让你一目了然……
一款php xml读取类,很简单的一个xml分析类了,它可读取指它xml文档,并且输出或取得指定节点的xml数据,本xml类代码是利用了php domdocument来解析xml文档。
java dom4j 解析xml文档 使用java操作xml 例如创建 读取 删除 等等
分析如何结合使用dom技术和sax技术解析xml文件,实现既可以读取大文档xml又可以实现简单操作xml文件
前台页面展示用zTree插件,后台数据用XML保存,利用Dom4j进行解析,涉及到了对XML的增、删、改等等特别需求的技术,并用struts2+spring进行整合项目,源代码中有非常完整的注释,导入myEclipse部署运行,即可从...