<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Chinese To English     英文 轉(zhuǎn) 中文             
             
    隨筆-27  評論-53  文章-0  trackbacks-0
    1、XML文件persons.xml內(nèi)容如下:

    <?xml version="1.0" encoding="UTF-8"?>
    <persons>
      
    <person><name>jak</name><sex></sex></person>
      
    <person>
        
    <name>jcy</name>
        
    <sex></sex>
      
    </person>
    </persons>

    2、java解析代碼如下:

     1 package net.vicp.jiasoft;
     2 
     3 import javax.xml.parsers.*;
     4 import java.io.IOException;
     5 import org.xml.sax.SAXException;
     6 import org.w3c.dom.Document;
     7 import org.w3c.dom.NodeList;
     8 import org.w3c.dom.Node;
     9 
    10 /**
    11  * <p>Title: Dom解析XML示例</p>
    12  *
    13  * <p>Description: Dom解析XML</p>
    14  *
    15  * <p>Copyright: Copyright (c) 2008</p>
    16  *
    17  * <p>Company: Jiasoft</p>
    18  *
    19  * @author Jak.Shen
    20  * @version 1.0
    21  */
    22 public class DomXml {
    23     public void parsersXml() {
    24         //實例化一個文檔構(gòu)建器工廠
    25         DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
    26         try {
    27             //通過文檔構(gòu)建器工廠獲取一個文檔構(gòu)建器
    28             DocumentBuilder db = dbf.newDocumentBuilder();
    29             //通過文檔通過文檔構(gòu)建器構(gòu)建一個文檔實例
    30             Document doc = db.parse("persons.xml");
    31             //獲取所有名字為 “person” 的節(jié)點
    32             NodeList nl1 = doc.getElementsByTagName("person");
    33             int size1 = nl1.getLength();
    34             for (int i = 0; i < size1; i++) {
    35                 Node n = nl1.item(i);
    36                 //獲取 n 節(jié)點下所有的子節(jié)點。此處值得注意,在DOM解析時會將所有回車都視為 n 節(jié)點的子節(jié)點。
    37                 NodeList nl2 = n.getChildNodes();
    38                 //因為上面的原因,在此例中第一個 n 節(jié)點有 2 個子節(jié)點,而第二個 n 節(jié)點則有 5 個子節(jié)點(因為多了3個回車)。
    39                 int size2 = nl2.getLength();
    40                 for (int j = 0; j < size2; j++) {
    41                     Node n2 = nl2.item(j);
    42                     //還是因為上面的原因,故此要處判斷當 n2 節(jié)點有子節(jié)點的時才輸出。
    43                     if (n2.hasChildNodes()) {
    44                         System.out.println(n2.getNodeName() + " = " +
    45                                            n2.getFirstChild().getNodeValue());
    46                     }
    47                 }
    48             }
    49         } catch (ParserConfigurationException ex) {
    50             ex.printStackTrace();
    51         } catch (IOException ex) {
    52             ex.printStackTrace();
    53         } catch (SAXException ex) {
    54             ex.printStackTrace();
    55         }
    56     }
    57 
    58     public static void main(String[] args) {
    59         DomXml domxml = new DomXml();
    60         domxml.parsersXml();
    61     }
    62 }




    杰森 
    郵箱:json.shen(at)gmail.com
    網(wǎng)站:www.shenjia.org
    posted on 2008-05-24 15:42 杰森 閱讀(13424) 評論(11)  編輯  收藏 所屬分類: JavaSE

    評論:
    # re: Java Dom解析XML 2008-05-27 10:12 | JAVA_START
    嘿嘿!  回復(fù)  更多評論
      
    # re: Java Dom解析XML[未登錄] 2008-08-08 15:55 | Scott.H
    <person id="1">
    </person>

    這里的id應(yīng)該怎么得到呢  回復(fù)  更多評論
      
    # re: Java Dom解析XML 2008-08-10 12:46 | Jak.Shen
    @Scott.H

    你說的id是person節(jié)點的屬性,屬性不是子節(jié)點,所以獲取上面所寫的nl1的屬性id即可。
    nl1.getAttributes();  回復(fù)  更多評論
      
    # re: Java Dom解析XML 2008-11-12 15:31 | 慕娉婷
    謝謝你!  回復(fù)  更多評論
      
    # re: Java Dom解析XML 2008-11-12 16:58 | Huaxu's
    @慕娉婷
    不用客氣!
      回復(fù)  更多評論
      
    # re: Java Dom解析XML 2011-06-22 09:48 | 李瀟
    謝了,這兩天一直糾結(jié)那個java dom解析xml為什么子節(jié)點數(shù)總是不對,總是多幾個,現(xiàn)在明白了,是把回車當子節(jié)點了,還需要多一層判斷。謝謝你的文章  回復(fù)  更多評論
      
    # re: Java Dom解析XML 2011-12-20 14:02 | dellheng
    多謝博主提醒:此處值得注意,在DOM解析時會將所有回車都視為 n 節(jié)點的子節(jié)點。
    我試用了以下幾種判斷
    if(childNode.hasChildNodes()) 有子節(jié)點或TextContent才行
    if(childNode.hasAttributes()) 有屬性才行
    if(childNode.getNodeName().equals("part")) 必須使用節(jié)點名稱
    這個最好 是判斷類型的
    if(childNode.getNodeType()==Node.ELEMENT_NODE)
    希望對大家有幫助  回復(fù)  更多評論
      
    # re: Java Dom解析XML[未登錄] 2012-05-22 19:37 | java
    怎么換個XML文件該程序就解析不了了啊  回復(fù)  更多評論
      
    # re: Java Dom解析XML[未登錄] 2012-06-03 16:19 | hello
    以前寫js的時候就郁悶了很久很久。。。@李瀟
      回復(fù)  更多評論
      
    # re: Java Dom解析XML 2012-07-16 15:26 | http://www.legow.cn/
    # re: Java Dom解析XML[未登錄] 2014-07-07 17:13 | howard
    怎么獲取name對應(yīng)的內(nèi)容是什么呢  回復(fù)  更多評論
      
    嗨117
    主站蜘蛛池模板: 亚洲国产精品无码久久一区二区| 日本免费大黄在线观看| 国产亚洲美女精品久久久| 久久精品国产免费一区| 亚洲成A人片在线播放器| 16女性下面无遮挡免费| 亚洲AV色无码乱码在线观看| 亚洲精品无码久久一线| 中文字幕无码不卡免费视频| 国产成人1024精品免费| 亚洲精品国产V片在线观看 | 成全视频免费高清| 九一在线完整视频免费观看| 亚洲人成网站日本片| 国产偷国产偷亚洲清高动态图| 亚洲免费日韩无码系列| 亚洲一欧洲中文字幕在线| 国产亚洲AV夜间福利香蕉149| 中文字幕av免费专区| 国产精品国产亚洲精品看不卡| 久久青青草原国产精品免费| 亚洲AV无码一区二区三区性色 | 亚洲成aⅴ人片在线观| xxxx日本免费| 本免费AV无码专区一区| 精品国产日韩亚洲一区在线| 亚洲激情电影在线| 免费无码黄网站在线观看| 蜜桃成人无码区免费视频网站| 亚洲日韩国产精品无码av| 国产亚洲一区区二区在线| 欧洲美熟女乱又伦免费视频| 91免费在线播放| 日本不卡免费新一区二区三区| 久久久亚洲裙底偷窥综合| 免费精品国偷自产在线在线 | 亚洲成a人在线看天堂无码| 久久精品免费一区二区喷潮| 久久福利资源网站免费看| 亚洲国产成人精品无码一区二区 | 精品久久8x国产免费观看|