Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2068049
  • 博文数量: 178
  • 博客积分: 2076
  • 博客等级: 大尉
  • 技术积分: 2800
  • 用 户 组: 普通用户
  • 注册时间: 2008-01-10 10:50
文章分类

全部博文(178)

文章存档

2010年(4)

2009年(13)

2008年(161)

我的朋友

分类: Java

2008-04-29 14:43:45

 
          
 
 
递归遍历XML所有元素

    做一个递归遍历XML的例子,为更为复杂的解析工作做基础。

    目标:遍历所有的元素节点,并且取出来其中的值,结果打印到控制台。

    源代码如下:
   
    本程序依赖DOM4j包。

 

import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.DocumentException;
import org.dom4j.Element;

import java.util.*;

/**
* Created by IntelliJ IDEA.

* User: leizhimin

* Date: 2008-4-14 14:02:12

* Note: 递归遍历XML所有元素
*/
public class XmlTest {

//    private static Map xmlmap = new HashMap();
    //xml元素信息的容器
    private static List elemList = new ArrayList();

    //要测试的xml对象
    private static String srcXml = "\n" +
            "\n" +
            "    \n" +
            "        某人\n" +
            "                    \n" +
            "            \n" +
            "                10002\n" +
            "                西安市太白路\n" +
            "           
\n" +
            "            \n" +
            "                10002\n" +
            "                空ID节点啊\n" +
            "           
\n" +
            "            \n" +
            "                10002\n" +
            "                空ID节点啊\n" +
            "           
\n" +
            "\t\t\t\n" +
            "\t\t\t\t\n" +
            "                西安市太白路2\n" +
            "           
\n" +
            "\t\t
\n" +
            "   
\n" +
            "    \n" +
            "        ASDF\n" +
            "   
\n" +
            "
";

    public static void main(String args[]) throws DocumentException {
        XmlTest test = new XmlTest();
        Element root = test.getRootElement();
        test.getElementList(root);
        String x = test.getListString(elemList);

        System.out.println("-----------原xml内容------------");
        System.out.println(srcXml);
        System.out.println("-----------解析结果------------");
        System.out.println(x);

    }

    /**
     * 获取根元素
     *
     * @return
     * @throws DocumentException
     */
    public Element getRootElement() throws DocumentException {
        Document srcdoc = DocumentHelper.parseText(srcXml);
        Element elem = srcdoc.getRootElement();
        return elem;
    }

    /**
     * 递归遍历方法
     *递归的出口点:判断是否有子元素
     * @param element
     */
    public void getElementList(Element element) {
        List elements = element.elements();
        if (elements.size() == 0) {
            //没有子元素
            String xpath = element.getPath();
            String value = element.getTextTrim();
            elemList.add(new Leaf(xpath, value));
        } else {
            //有子元素
            for (Iterator it = elements.iterator(); it.hasNext();) {
                Element elem = (Element) it.next();
                //递归遍历
                getElementList(elem);
            }
        }
    }

    public String getListString(List elemList) {
        StringBuffer sb = new StringBuffer();
        for (Iterator it = elemList.iterator(); it.hasNext();) {
            Leaf leaf = it.next();
            sb.append(leaf.getXpath()).append(" = ").append(leaf.getValue()).append("\n");
        }
        return sb.toString();
    }
}

    /**
    * xml节点数据结构
    */
class Leaf {
    private String xpath;         //
    private String value;

    public Leaf(String xpath, String value) {
        this.xpath = xpath;
        this.value = value;
    }

    public String getXpath() {
        return xpath;
    }

    public void setXpath(String xpath) {
        this.xpath = xpath;
    }

    public String getValue() {
        return value;
    }

    public void setValue(String value) {
        this.value = value;
    }
}

    运行结果:
-----------原xml内容------------



   
        某人
       
           
                10002
                西安市太白路
           

           
                10002
                空ID节点啊
           

           
                10002
                空ID节点啊
           

     
   
                西安市太白路2
           

 

   

   
        ASDF
   



-----------解析结果------------

/doc/person/name = 某人
/doc/person/adds/add/BS = 10002
/doc/person/adds/add/note = 西安市太白路
/doc/person/adds/add/BS = 10002
/doc/person/adds/add/note = 空ID节点啊
/doc/person/adds/add/BS = 10002
/doc/person/adds/add/note = 空ID节点啊
/doc/person/adds/add/*[name()='BS'] =
/doc/person/adds/add/note = 西安市太白路2
/doc/other/name = ASDF

Process finished with exit code 0

    可以发现,有很多xpath相同的值域。

 
一。获得根元素(常用的做法,如编历贴子一样,也要获得根点)
Document documnet    =        SAXReader.read(new File("a.xml");
              Element root =document.getRootElement();
二。编历xml
      List elements = element.elements(); 得到element 的子elements LIST
        递 归的出口:如果list.size()==0表明elment有子元素所以我就拿出text,如果
有,就调用 方法

      
阅读(702) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~