zoukankan      html  css  js  c++  java
  • java 解析 XML实例

    package com.hseact.fecp.servlet;
    
    import java.io.IOException;
    
    import javax.xml.parsers.DocumentBuilder;
    import javax.xml.parsers.DocumentBuilderFactory;
    import javax.xml.parsers.ParserConfigurationException;
    
    import org.json.JSONObject;
    import org.json.XML;
    import org.w3c.dom.Document;
    import org.w3c.dom.NamedNodeMap;
    import org.w3c.dom.Node;
    import org.w3c.dom.NodeList;
    import org.xml.sax.SAXException;
    
    /**
     * DOM方式解析xml
     */
    public class DOMTest {
    
        public static void main(String[] args) {
            //1、创建一个DocumentBuilderFactory的对象
            DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
            //2、创建一个DocumentBuilder的对象
            try {
                //创建DocumentBuilder对象
                DocumentBuilder db = dbf.newDocumentBuilder();
                //3、通过DocumentBuilder对象的parser方法加载books.xml文件到当前项目下
                /*注意导入Document对象时,要导入org.w3c.dom.Document包下的*/
                Document document = db.parse("WebContent\template\demo.svg");//传入文件名可以是相对路径也可以是绝对路径
    
                //获取所有book节点的集合
                NodeList bookList = document.getElementsByTagName("svg");
                //通过nodelist的getLength()方法可以获取bookList的长度
                System.out.println("一共有" + bookList.getLength() + "本书");
                //遍历每一个book节点
                for (int i = 0; i < bookList.getLength(); i++) {
                    System.out.println("=================下面开始遍历第" + (i + 1) + "本书的内容=================");
            //❤未知节点属性的个数和属性名时:
                    //通过 item(i)方法 获取一个book节点,nodelist的索引值从0开始
                    Node book = bookList.item(i);
                    //获取book节点的所有属性集合
                    NamedNodeMap attrs = book.getAttributes();
                    System.out.println("第 " + (i + 1) + "本书共有" + attrs.getLength() + "个属性");
                    //遍历book的属性
                    for (int j = 0; j < attrs.getLength(); j++) {
                        //通过item(index)方法获取book节点的某一个属性
                        Node attr = attrs.item(j);
                        //获取属性名
                        System.out.print("属性名:" + attr.getNodeName());
                        //获取属性值
                        System.out.println("--属性值" + attr.getNodeValue());
                    }
       
    
                    NodeList childNodes = book.getChildNodes();
                  //遍历childNodes获取每个节点的节点名和节点值
                    System.out.println("第" + (i+1) + "本书共有" + childNodes.getLength() + "个子节点");
                    for (int k = 0; k < childNodes.getLength(); k++) {
                      //区分出text类型的node以及element类型的node
                        if(childNodes.item(k).getNodeType() == Node.ELEMENT_NODE){
                          //获取了element类型节点的节点名
                            System.out.print("第" + (k + 1) + "个节点的节点名:" + childNodes.item(k).getNodeName());
                          //获取了element类型节点的节点值
                           // System.out.println("--节点值是:" + childNodes.item(k).getFirstChild().getNodeValue());
                         //遍历book的属性
                            NamedNodeMap eleAttrs = childNodes.item(k).getAttributes();
                            for (int j = 0; j < eleAttrs.getLength(); j++) {
                                //通过item(index)方法获取book节点的某一个属性
                                Node attr = eleAttrs.item(j);
                                //获取属性名
                                System.out.print("属性名:" + attr.getNodeName());
                                //获取属性值
                                System.out.println("--属性值" + attr.getNodeValue());
                            } 
                        }
                    }
                    System.out.println("======================结束遍历第" + (i + 1) + "本书的内容=================");
                }
    
            } catch (ParserConfigurationException e) {
                e.printStackTrace();
            } catch (SAXException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    
    }
    

      

  • 相关阅读:
    转载ORACLE批量绑定FORALL与BULK COLLECT
    Oracle Locking Survival Guide
    转载:TOAD中查看执行计划
    Oracle 9i/10g编程艺术笔记第七章 并发与多版本
    C#调用Oracle存储过程返回多结果集
    转载oracle 字符集查看与修改
    转载:Oracle的优化器(Optimizer)
    Oracle 随笔
    转载:Oracle中SQL语句执行效率的查找与解决
    当查询和设置需要输入Pn时界面的处理方法
  • 原文地址:https://www.cnblogs.com/pangguoming/p/6549906.html
Copyright © 2011-2022 走看看