博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
XML的DOM解析 Java实现 使用递归解析一个XML文档
阅读量:5060 次
发布时间:2019-06-12

本文共 2960 字,大约阅读时间需要 9 分钟。

 

XML的DOM解析 Java实现 使用递归解析一个XML文档

 

  本文是一个练习程序,程序解析了一个XML文档,并将其原样输出在命令行上。

  因为要把程序设计成适用于任何XML文档,所以需要使用递归,其中还必须加入元素类型的判断。

  详见程序:

  本文使用的XML文档:

 

<学生名册 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:nonamespaceschemalocation="C:\Course30\student.xsd">
<学生 学号="1">
<姓名>
张三
<性别>
<年龄>
20
<学生 学号="2">
<姓名>
李四
<性别>
<年龄>
19
<学生 学号="3">
<姓名>
王五
<性别>
<年龄>
21

 

 

  Java程序:

 

package com.learnjava.xml.dom;import java.io.File;import javax.xml.parsers.DocumentBuilder;import javax.xml.parsers.DocumentBuilderFactory;import org.w3c.dom.Attr;import org.w3c.dom.Comment;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;/** * 使用递归解析一个XML文档并且将其内容输出到命令行上 *  */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"));        // 获取根元素节点        Element root = doc.getDocumentElement();        parseElement(root);    }    private static void parseElement(Element element)    {        String tagName = element.getNodeName();        System.out.print("<" + tagName);        // element元素的所有属性构成的NamedNodeMap对象,需要对其进行判断        NamedNodeMap map = element.getAttributes();        // 如果存在属性,则打印属性        if (null != map)        {            for (int i = 0; i < map.getLength(); i++)            {                // 获得该元素的每一个属性                Attr attr = (Attr) map.item(i);                // 属性名和属性值                String attrName = attr.getName();                String attrValue = attr.getValue();                // 注意属性值需要加上引号,所以需要\转义                System.out.print(" " + attrName + "=\"" + attrValue + "\"");            }        }        // 关闭标签名        System.out.print(">");        // 至此已经打印出了元素名和其属性        // 下面开始考虑它的子元素        NodeList children = element.getChildNodes();        for (int i = 0; i < children.getLength(); i++)        {            // 获取每一个child            Node node = children.item(i);            // 获取节点类型            short nodeType = node.getNodeType();            if (nodeType == Node.ELEMENT_NODE)            {                // 如果是元素类型,则递归输出                parseElement((Element) node);            }            else if (nodeType == Node.TEXT_NODE)            {                // 如果是文本类型,则输出节点值,及文本内容                System.out.print(node.getNodeValue());            }            else if (nodeType == Node.COMMENT_NODE)            {                // 如果是注释,则输出注释                System.out.print("
"); } } // 所有内容处理完之后,输出,关闭根节点 System.out.print("
"); }}

 

 

 

 

参考资料

  圣思园张龙老师视频教程。

  Java官方文档:

转载于:https://www.cnblogs.com/mengdd/archive/2013/06/02/3113459.html

你可能感兴趣的文章
linux -- 嵌入式linux下wifi无线网卡驱动
查看>>
SVN使用教程总结
查看>>
SQL中varchar和nvarchar有什么区别?
查看>>
OpenCV矩阵运算总结
查看>>
Java Build Practice 4:Extend and Invoke Ant API
查看>>
[转] Transformer图解
查看>>
FreeBSD方式安装 MAC OSX
查看>>
Linux 根文件系统制作
查看>>
IOS--沙盒机制
查看>>
使用 JointCode.Shuttle 访问任意 AppDomain 的服务
查看>>
sqlite的坑
查看>>
digitalocean --- How To Install Apache Tomcat 8 on Ubuntu 16.04
查看>>
linux swoole
查看>>
【题解】[P4178 Tree]
查看>>
Jquery ui widget开发
查看>>
更改git仓库地址
查看>>
有标号DAG计数 [容斥原理 子集反演 组合数学 fft]
查看>>
Recipe 1.4. Reversing a String by Words or Characters
查看>>
Rule 1: Make Fewer HTTP Requests(Chapter 1 of High performance Web Sites)
查看>>
sql注入
查看>>