递归方式 DOM 解析(parse) XML
friends.xml
- <span style="font-size:16px;"><?xml version="1.0" encoding="utf-8"?>
- <friends date="2012">
- <!--此处为注释-->
- <friend id="1">
- <姓名>小红</姓名>
- <QQ>123456789</QQ>
- </friend>
- <friend>
- <姓名>小平</姓名>
- <QQ>12345678</QQ>
- </friend>
- <friend>
- <姓名 mark="hello">小敏</姓名>
- <QQ>1234567</QQ>
- </friend>
- <friend>
- <姓名>小良</姓名>
- <QQ>987654321</QQ>
- </friend>
- <friend>
- <姓名>小健</姓名>
- <QQ>98765432</QQ>
- </friend>
- </friends>
- </span>
DOM parse XML
- <span style="font-size:16px;">import java.io.File ;
- import javax.xml.parsers.DocumentBuilderFactory ;
- import javax.xml.parsers.DocumentBuilder ;
- import org.w3c.dom.Element ;
- import org.w3c.dom.Document ;
- import org.w3c.dom.NamedNodeMap ;
- import org.w3c.dom.NodeList ;
- import org.w3c.dom.Attr ;
- import org.w3c.dom.Node ;
- import org.w3c.dom.Comment ;
- //利用 递归 dom 解析任何xml文档,把xml文档加载到内存,占用内存大,可随机访问
- public class RecursionDOM_XML
- {
- public static void main(String[] args) throws Exception
- {
- //1.获取dom解析器工厂
- DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance() ;
- //2.获取具体的dom解析器
- DocumentBuilder db = dbf.newDocumentBuilder() ;
- //获取xml文档的 根节点
- Document document = db.parse(new File("friends.xml") );
- //获取文档的 根元素节点
- Element e = document.getDocumentElement() ;
- parseXML(e) ;
- }
- public static void parseXML(Element element)
- {
- //获取 元素节点 的 信息
- String name = element.getNodeName() ;
- System.out.print("< " + name) ;
- //获取此元素节点的属性
- NamedNodeMap map = element.getAttributes() ;
- //获取目前element元素节点下的 孩子节点(包括空格)</span>
- <span style="font-size:16px;"> NodeList child = element.getChildNodes() ;
- if (null != map)
- {
- for (int i = 0; i < map.getLength(); i++ )
- {
- Attr attr = (Attr)map.item(i) ;
- String name1 = attr.getName() ;
- String value1 = attr.getValue() ;
- System.out.print(" " + name1 +"=\"" + value1 +"\"") ;
- }
- }
- System.out.print(" >") ;
- for (int j = 0; j < child.getLength() ;j++ )
- {
- Node node = child.item(j) ;
- //判断该节点是不是 元素节点 ,递归路口
- if (node.getNodeType() == Node.ELEMENT_NODE)
- {
- //开始递归
- parseXML((Element)node) ;
- }
- //判断该节点是不是 文本,递归出口
- else if (node.getNodeType() == Node.TEXT_NODE)
- {
- System.out.print(node.getNodeValue() + "") ;
- }
- //判断该节点是不是 注释
- else if (node.getNodeType() == Node.COMMENT_NODE)
- {
- System.out.print("<!--");
- Comment comment = (Comment)node ;
- //注释内容
- String data = comment.getData() ;
- System.out.print(data);
- System.out.print("-->");
- }
- }
- System.out.println("</" + name + ">" ) ;
- }
- }</span>
递归方式 DOM 解析(parse) XML的更多相关文章
- mybatis源码-解析配置文件(一)之XML的DOM解析方式
目录 简介 Java 中 XML 文件解析 解析方式 DOM 解析 XML 新建 XML 文件 DOM 操作相关类 Java 读取 XML 文件 一起学 mybatis @ 简介 在之前的文章< ...
- XML 解析---dom解析和sax解析
眼下XML解析的方法主要用两种: 1.dom解析:(Document Object Model.即文档对象模型)是W3C组织推荐的解析XML的一种方式. 使用dom解析XML文档,该解析器会先把XML ...
- Java Dom解析xml
Dom解析是将xml文件全部载入,组装成一颗dom树,然后通过节点以及节点之间的关系来解析xml文件,下面结合这个xml文件来进行dom解析. <?xml version="1.0&q ...
- 简单谈谈dom解析xml和html
前言 文件对象模型(Document Object Model,简称DOM),是W3C组织推荐的处理可扩展标志语言的标准编程接口.html,xml都是基于这个模型构造的.这也是一个W3C推出的标准.j ...
- android XML解析之DOM解析方式
DOM 解析方式步骤: 第一步:首选需要获得DOM解析器工厂实例 DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance ...
- java xml解析方式(DOM、SAX、JDOM、DOM4J)
XML值可扩展标记语言,是用来传输和存储数据的. XMl的特定: XMl文档必须包含根元素.该元素是所有其他元素的父元素.XML文档中的元素形成了一颗文档树,树中的每个元素都可存在子元素. 所有XML ...
- 用java操作XML文件(DOM解析方式)
XML 可扩展标记语言(Extensible Markup Language),是独立于软件和硬件的传输工具. XML的作用: (1)用作配置文件 (2)简化数据共享 (3)简化数据传输 XML DO ...
- XML的解析方式(DOM、SAX、StAX)
(新) XML的解析方式(DOM.SAX.StAX) 博客分类: XML 一般来说,解析XML文件存在着两种方式,一种是event-based API,比如说象SAX,XNI. 第二种是tree ...
- java解析xml的方式DOM,SAX,DOM4J,JDOM,StAX
1)DOM(JAXP Crimson解析器)DOM是用与平台和语言无关的方式表示XML文档的官方W3C标准.DOM是以层次结构组织的节点或信息片断的集合.这个层次结构允许开发人员在树中寻找 特定信息. ...
随机推荐
- MODI出现ORC RUNNING ERROR的解决方法
stackflow都没个靠谱的说法,最后还是csdn上看到的.转一个备用.http://bbs.csdn.net/topics/390135443 由于直接执行Mircosoft Office Doc ...
- Swift 自定义打印方法
Swift 自定义打印方法 代码如下 // MARK:- 自定义打印方法 func MLLog<T>(_ message : T, file : String = #file, funcN ...
- ECMAScript5严格模式
ECMAScript5引入了严格模式(strict mode)的概念,IE10+开始支持.严格模式为JavaScript定义了一种不同的解析和执行模型,在严格模式下,ECMAScript3中的一些不确 ...
- 《C# to IL》第三章 选择和循环
在IL中,标号(label)是一个末尾带有冒号(即:)的名称.它使我们能够从代码的一部分无条件地跳转到另一部分.我们经常在由反编译器生成的IL代码中看到这个标号.例如: IL_0000: ldstr ...
- Lower dc/dc-converter ripple by using optimum capacitor hookup
Low-ripple-voltage positive-to-negative dc/dc converters find use in many of today's high- frequency ...
- Spring SimpleJdbcTemplate查询示例
这里有几个例子来说明如何使用SimpleJdbcTemplate query()方法来查询或从数据库中提取数据.在 JdbcTemplate query() 方法,需要手动转换返回的结果转换为一个目标 ...
- Go语言设计模式实践:迭代器(Iterator)
关于本系列 决定开个新坑. 这个系列首先是关于Go语言实践的.在项目中实际使用Go语言也有段时间了,一个体会就是不论是官方文档.图书还是网络资料,关于Go语言惯用法(idiom)的介绍都比较少,基本只 ...
- [置顶] linux学习之静态库和动态库的制作与使用
linux中静态库和动态库的制作与使用 一.静态链接库 1.首先编写模块程序example.c.example.h 2.使用gcc -c example.c -o example.o编译example ...
- c++多行字符串,可以这么写
c++多行字符串,可以这么写:CString s;s.Format("CREATE TABLE %s(\[ID] [int] IDENTITY(1,1) NOT NULL,\[Vendor] ...
- linux文件系统命令(6)---touch和mkdir
一.目的 本文将介绍linux下新建文件或文件夹.删除文件或文件夹命令. touch能够新建文件,mkdir用来新建文件夹.rm用来删除文件或文件夹. 本文将选取ubu ...