目标:使用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 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相同的值域。
【编辑推荐】
- 高手Java核心技术学习笔记
 - 如何使用 JavaScript XSLT 处理 XML 文件
 - JSP结合XML+XSLT将输出转换HTML
 - Java通过JNI调用C语言的方法
 - JAVA环境变量的设置
 
            
                分享题目:Dom4j递归遍历XML所有元素
                
                标题来源:http://www.csdahua.cn/qtweb/news19/472269.html
            
            
                网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
                                
            
                广告
                
            
            
                声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源:
                快上网