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

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

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

    dom4j實例 的Xpath解析 轉

    books.xml:

    <?xml version="1.0" encoding="UTF-8"?>  
        
    <books>  
            
    <!--This is a test for dom4j, jakoes, 2007.7.19-->  
            
    <book show="yes" url="lucene.net">  
                
    <title id="456">Lucene Studing</title>  
            
    </book>  
            
    <book show="yes" url="dom4j.com">  
                
    <title id="123">Dom4j Tutorials</title>  
            
    </book>  
            
    <book show="no" url="spring.org">  
                
    <title id="789">Spring in Action</title>  
            
    </book>  
            
    <owner>O'Reilly</owner>  
        </books> 



    public void parseBooks(){  
             
            SAXReader reader 
    = new SAXReader();  
            
    try {  
                Document doc 
    = reader.read("books.xml");  
                Node root 
    = doc.selectSingleNode("/books");  
                List list 
    = root.selectNodes("book[@url='dom4j.com']");  
                 
                
    for(Object o:list){  
                     
                    Element e 
    = (Element) o;  
                    String show
    =e.attributeValue("show");  
                    System.out.println(
    "show = " + show);  
                }  
                
            } 
    catch (Exception e) {  
                e.printStackTrace();  
            }  
        }  
    Document doc 
    = reader.read("books.xml");的意思是加載XML文檔,此是可以用doc.asXML()來查看,它將打印整個xml文檔。

      Node root 
    = doc.selectSingleNode("/books");是讀取剛才加載的xml文檔內的books節點下的所有內容,對于本例也是整個xml文檔。
      當然我們也可以加載
    /books下的某一個節點,如:book節點
    Node root 
    = doc.selectSingleNode("/books/book");
    或:Node root 
    = doc.selectSingleNode("/books/*");
    注意:如果有多個book節點,它只會讀取第一個
    root.asXML()將打印:
    <book show="yes" url="lucene.net">
            
    <title id="456">Lucene Studing</title>
    </book>

      既然加載了這么多,那我怎么精確的得到我想要的節點呢,別急,看下面:
    List list 
    = root.selectNodes("book[@url='dom4j.com']");
    它的意思就是讀取books節點下的book節點,且book的節點的url屬性為dom4j.com
    為什么使用list來接收呢,如果有兩個book節點,且它們的url屬性都為dom4j.com,此時就封閉到list里了。

      如果想讀取books下的所有book節點,可以這樣:
    List list 
    = root.selectNodes("book");

      如果想讀取books節點下的book節點下的title節點,可以這樣:
    List list2 
    = root.selectNodes("book[@url='dom4j.com']/title[@id='123']");

      注意:selectNodes()參數的格式:
      節點名[@屬性名
    ='屬性值'],如:book[@url='dom4j.com']
      如果有多個節點,用“
    /”分開,如:book[@url='dom4j.com']/title[@id='123']

      最近就是讀取封閉在List里的內容了,可以用Node來讀取,也可以用Element來轉換。
    attributeValue(
    "屬性")是讀取該節點的屬性值
    getText()是讀取節點的的內容。




    posted on 2012-06-14 08:56 youngturk 閱讀(1092) 評論(0)  編輯  收藏 所屬分類: 幾種文檔解析

    <2012年6月>
    272829303112
    3456789
    10111213141516
    17181920212223
    24252627282930
    1234567

    導航

    統計

    公告

    this year :
    1 jQuery
    2 freemarker
    3 框架結構
    4 口語英語

    常用鏈接

    留言簿(6)

    隨筆分類

    隨筆檔案

    文章分類

    文章檔案

    相冊

    EJB學習

    Flex學習

    learn English

    oracle

    spring MVC web service

    SQL

    Struts

    生活保健

    解析文件

    搜索

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 99ee6热久久免费精品6| 亚洲精品天堂在线观看| 国产精品亚洲综合一区| 亚洲 小说区 图片区 都市| 免费A级毛片无码A∨男男| 青青草国产免费久久久下载| 成人免费视频网址| 香蕉高清免费永久在线视频| 在线成人a毛片免费播放| 在线免费一区二区| 国产无遮挡吃胸膜奶免费看视频| 在线视频免费国产成人| 国产成人免费手机在线观看视频 | 亚洲av无码专区在线电影天堂| 亚洲成_人网站图片| 亚洲人成人伊人成综合网无码| 亚洲妇女无套内射精| 国产成人亚洲午夜电影| 黄网站色成年片大免费高清| 无码 免费 国产在线观看91| 国产特黄特色的大片观看免费视频| 国产免费播放一区二区| 好紧我太爽了视频免费国产| 足恋玩丝袜脚视频免费网站| 美女网站免费福利视频| 国产精品自在自线免费观看| 亚洲国产精品国产自在在线 | 免费在线观看视频网站| 大地资源二在线观看免费高清| 色www永久免费视频| 亚洲乱码国产一区网址| 狠狠综合久久综合88亚洲| 亚洲大片在线观看| 亚洲AV无码乱码麻豆精品国产| 精品国产_亚洲人成在线| aa在线免费观看| 亚欧免费视频一区二区三区| 国产网站免费观看| 亚洲va久久久噜噜噜久久男同 | 亚洲一级Av无码毛片久久精品| 亚洲精品无码mv在线观看网站|