本篇内容介绍了“Dom4j怎么递归遍历XML所有元素”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
目标:使用JOM4j遍历所有的元素节点,并且取出来其中的值,结果打印到控制台。 源代码如下:本程序依赖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: Java递归遍历XML所有元素 
*/ 
public class XmlTest { 
//    private static Mapxmlmap = new HashMap(); 
    //存储xml元素信息的容器 
    private static ListelemList = 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(ListelemList) { 
        StringBuffer sb = new StringBuffer(); 
        for (Iteratorit = 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节点啊西安市太白路2ASDF-----------解析结果------------ 
/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相同的值域。
“Dom4j怎么递归遍历XML所有元素”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!