隨筆-9  評(píng)論-168  文章-266  trackbacks-0

          一.Document對(duì)象,三種創(chuàng)建方法

          1.讀取XML文件,獲得document對(duì)象.
                      SAXReader reader = new SAXReader();
                      Document  document = reader.read(new File("input.xml"));

          2.解析XML格式的字符串,獲得document對(duì)象.
                      String text = "<members></members>";
                      Document document = DocumentHelper.parseText(text);
          3.創(chuàng)建document空對(duì)象.
                      Document document = DocumentHelper.createDocument();
                      Element  root = document.addElement("members");// 創(chuàng)建根節(jié)點(diǎn),只有空DOCUMENT對(duì)象才能創(chuàng)建ROOT結(jié)點(diǎn)


          二.節(jié)點(diǎn)控制

          1.獲取文檔的根節(jié)點(diǎn).
                     Element   root = document.getRootElement();
          2.取得節(jié)點(diǎn)的文本
                     String text=memberElm.getText();
          也可以用:
                     String text=root.elementText("name");   //這個(gè)是取得根節(jié)點(diǎn)下的name字節(jié)點(diǎn)的文字;可以類推任何節(jié)點(diǎn)下的文本
          3.設(shè)置節(jié)點(diǎn)文字.
                     ageElm.setText("29");
          4.父節(jié)點(diǎn)下獲得單個(gè)子節(jié)點(diǎn)對(duì)象.
                     Element memberElm=root.element("member");  // "member"是節(jié)點(diǎn)名

          5.取得父節(jié)點(diǎn)下遍歷名為"member"的所有子節(jié)點(diǎn).
                     List nodes = rootElm.elements("member");
                     for (Iterator it = nodes.iterator(); it.hasNext();) {
                           Element elm = (Element) it.next();
                           // do something
                      }
          6.父節(jié)點(diǎn)下的遍歷所有子節(jié)點(diǎn)進(jìn)行.
                      for(Iterator it=root.elementIterator();it.hasNext();){
                          Element element = (Element) it.next();
                          // do something
                      }
          7.父節(jié)點(diǎn)下添加子節(jié)點(diǎn).
                     Element ageElm = newMemberElm.addElement("age");

          8.父節(jié)點(diǎn)下刪除子節(jié)點(diǎn).
                     parentElm.remove(childElm);// childElm是待刪除的節(jié)點(diǎn),parentElm是其父節(jié)點(diǎn)

          三.屬性相關(guān).
          1.取得某節(jié)點(diǎn)下的某屬性
                      Element root=document.getRootElement();   
                      Attribute attribute=root.attribute("size");// 屬性名name
          2.取得屬性的文字
                      String text=attribute.getText();
          也可以用:
          String text2=root.element("name").attributeValue("firstname");這個(gè)是取得根節(jié)點(diǎn)下name字節(jié)點(diǎn)的屬性firstname的值.

          3.遍歷某節(jié)點(diǎn)的所有屬性
                      Element root=document.getRootElement();   
                      for(Iterator it=root.attributeIterator();it.hasNext();){
                          Attribute attribute = (Attribute) it.next();
                          String text=attribute.getText();
                          System.out.println(text);
                      }
          4.設(shè)置某節(jié)點(diǎn)的屬性和文字.
          newMemberElm.addAttribute("name", "sitinspring");
          5.設(shè)置屬性的文字
                      Attribute attribute=root.attribute("name");
                      attribute.setText("sitinspring");
          6.刪除某屬性
                      Attribute attribute=root.attribute("size");// 屬性名name
                      root.remove(attribute);
          四.將文檔寫入XML文件.
          1.文檔中全為英文,不設(shè)置編碼,直接寫入的形式.
          XMLWriter writer = new XMLWriter(new FileWriter("output.xml"));
          writer.write(document);
          writer.close();
          2.文檔中含有中文,設(shè)置編碼格式寫入的形式.
                      OutputFormat format = OutputFormat.createPrettyPrint();
                      format.setEncoding("GBK");    // 指定XML編碼       
                      XMLWriter writer = new XMLWriter(new FileWriter("output.xml"),format);
                     
                      writer.write(document);
                      writer.close();
          五.字符串與XML的轉(zhuǎn)換
          1.將字符串轉(zhuǎn)化為XML
          String text = "<members> <member>sitinspring</member> </members>";
          Document document = DocumentHelper.parseText(text);
          2.將文檔或節(jié)點(diǎn)的XML轉(zhuǎn)化為字符串.
                      SAXReader reader = new SAXReader();
                      Document  document = reader.read(new File("input.xml"));           
                      Element root=document.getRootElement();               
                      String docXmlText=document.asXML();
                      String rootXmlText=root.asXML();
                      Element memberElm=root.element("member");
                      String memberXmlText=memberElm.asXML();
          六.使用XPath快速找到節(jié)點(diǎn).
          讀取的XML文檔示例
          <?xml version="1.0" encoding="UTF-8"?>
          <projectDescription>
            <name>MemberManagement</name>
            <comment></comment>
            <projects>
              <project>PRJ1</project>
              <project>PRJ2</project>
              <project>PRJ3</project>
              <project>PRJ4</project>
            </projects>
            <buildSpec>
              <buildCommand>
                <name>org.eclipse.jdt.core.javabuilder</name>
                <arguments>
                </arguments>
              </buildCommand>
            </buildSpec>
            <natures>
              <nature>org.eclipse.jdt.core.javanature</nature>
            </natures>
          </projectDescription>

          使用XPath快速找到節(jié)點(diǎn)project.
           public static void main(String[] args){
              SAXReader reader = new SAXReader();
             
              try{
                Document  doc = reader.read(new File("sample.xml"));
               
                List projects=doc.selectNodes("/projectDescription/projects/project");
               //Element nodes0=xmlDoc.selectSingleNode("/bookstore"); //采用相對(duì)路徑,即當(dāng)前結(jié)點(diǎn)(包括當(dāng)前結(jié)點(diǎn))開始查找,與下列結(jié)果相同.
               //Element nodes=nodes0.selectNodes("book");      ////采用絕對(duì)路徑,即當(dāng)前結(jié)點(diǎn)(包括當(dāng)前結(jié)點(diǎn))開始查找,
               //XPATH語法詳見: http://www.w3school.com.cn/xpath/xpath_syntax.asp


                Iterator it=projects.iterator();
               
                while(it.hasNext()){
                  Element elm=(Element)it.next();      
                  System.out.println(elm.getText());
                }
               
              }
              catch(Exception ex){
                 ex.printStackTrace();
              }
            }

          posted on 2010-11-23 11:35 紫蝶∏飛揚(yáng)↗ 閱讀(1125) 評(píng)論(0)  編輯  收藏 所屬分類: JAVAJSP
          <2025年7月>
          293012345
          6789101112
          13141516171819
          20212223242526
          272829303112
          3456789

          常用鏈接

          留言簿(5)

          隨筆檔案(9)

          文章分類(339)

          文章檔案(265)

          最新隨筆

          最新評(píng)論

          閱讀排行榜

          評(píng)論排行榜

          主站蜘蛛池模板: 连云港市| 米林县| 东至县| 广汉市| 马山县| 修水县| 紫阳县| 阿鲁科尔沁旗| 龙游县| 湟中县| 曲周县| 大丰市| 通河县| 资溪县| 招远市| 建阳市| 盘山县| 西乌| 哈密市| 龙州县| 江永县| 库伦旗| 黄梅县| 梅河口市| 克什克腾旗| 从化市| 通化市| 祥云县| 龙口市| 镇坪县| 驻马店市| 邯郸市| 梁山县| 桃园市| 都昌县| 府谷县| 巨鹿县| 辉南县| 焦作市| 汨罗市| 无棣县|