java下dom4j的使用

来源:互联网 发布:网络订餐设计任务 编辑:程序博客网 时间:2024/06/06 01:40

xml的解析工具有哪些,优缺点就不在这里描述了。

目前推荐采用dom4j,所以这里只是讨论使用dom4j。

看到一篇文章,例子很好,这里转载下:

http://www.cnblogs.com/macula/archive/2011/07/27/2118003.html

[java] view plaincopy
  1. //先加入dom4j.jar包  
  2. import java.util.HashMap;  
  3. import java.util.Iterator;  
  4. import java.util.Map;  
  5.   
  6. import org.dom4j.Document;  
  7. import org.dom4j.DocumentException;  
  8. import org.dom4j.DocumentHelper;  
  9. import org.dom4j.Element;  
  10.   
  11. /** 
  12.  * @description 解析xml字符串 
  13.  * @author 无处不在 
  14.  * @Time 上午11:01:31 
  15.  */  
  16. public class Test {  
  17.   
  18.     public void readStringXml(String xml) {  
  19.         Document doc = null;  
  20.         try {  
  21.   
  22.             // 读取并解析XML文档  
  23.             // SAXReader就是一个管道,用一个流的方式,把xml文件读出来  
  24.             //  
  25.             // SAXReader reader = new SAXReader(); //User.hbm.xml表示你要解析的xml文档  
  26.             // Document document = reader.read(new File("User.hbm.xml"));  
  27.             // 下面的是通过解析xml字符串的  
  28.             doc = DocumentHelper.parseText(xml); // 将字符串转为XML  
  29.   
  30.             Element rootElt = doc.getRootElement(); // 获取根节点  
  31.             System.out.println("根节点:" + rootElt.getName()); // 拿到根节点的名称  
  32.   
  33.             Iterator iter = rootElt.elementIterator("head"); // 获取根节点下的子节点head  
  34.   
  35.             // 遍历head节点  
  36.             while (iter.hasNext()) {  
  37.   
  38.                 Element recordEle = (Element) iter.next();  
  39.                 String title = recordEle.elementTextTrim("title"); // 拿到head节点下的子节点title值  
  40.                 System.out.println("title:" + title);  
  41.   
  42.                 Iterator iters = recordEle.elementIterator("script"); // 获取子节点head下的子节点script  
  43.   
  44.                 // 遍历Header节点下的Response节点  
  45.                 while (iters.hasNext()) {  
  46.   
  47.                     Element itemEle = (Element) iters.next();  
  48.   
  49.                     String username = itemEle.elementTextTrim("username"); // 拿到head下的子节点script下的字节点username的值  
  50.                     String password = itemEle.elementTextTrim("password");  
  51.   
  52.                     System.out.println("username:" + username);  
  53.                     System.out.println("password:" + password);  
  54.                 }  
  55.             }  
  56.             Iterator iterss = rootElt.elementIterator("body"); ///获取根节点下的子节点body  
  57.             // 遍历body节点  
  58.             while (iterss.hasNext()) {  
  59.   
  60.                 Element recordEless = (Element) iterss.next();  
  61.                 String result = recordEless.elementTextTrim("result"); // 拿到body节点下的子节点result值  
  62.                 System.out.println("result:" + result);  
  63.   
  64.                 Iterator itersElIterator = recordEless.elementIterator("form"); // 获取子节点body下的子节点form  
  65.                 // 遍历Header节点下的Response节点  
  66.                 while (itersElIterator.hasNext()) {  
  67.   
  68.                     Element itemEle = (Element) itersElIterator.next();  
  69.   
  70.                     String banlce = itemEle.elementTextTrim("banlce"); // 拿到body下的子节点form下的字节点banlce的值  
  71.                     String subID = itemEle.elementTextTrim("subID");  
  72.   
  73.                     System.out.println("banlce:" + banlce);  
  74.                     System.out.println("subID:" + subID);  
  75.                 }  
  76.             }  
  77.         } catch (DocumentException e) {  
  78.             e.printStackTrace();  
  79.   
  80.         } catch (Exception e) {  
  81.             e.printStackTrace();  
  82.   
  83.         }  
  84.     }  
  85.   
  86.     /** 
  87.      * @description 将xml字符串转换成map 
  88.      * @param xml 
  89.      * @return Map 
  90.      */  
  91.     public static Map readStringXmlOut(String xml) {  
  92.         Map map = new HashMap();  
  93.         Document doc = null;  
  94.         try {  
  95.             doc = DocumentHelper.parseText(xml); // 将字符串转为XML  
  96.             Element rootElt = doc.getRootElement(); // 获取根节点  
  97.             System.out.println("根节点:" + rootElt.getName()); // 拿到根节点的名称  
  98.   
  99.             Iterator iter = rootElt.elementIterator("head"); // 获取根节点下的子节点head  
  100.             // 遍历head节点  
  101.             while (iter.hasNext()) {  
  102.   
  103.                 Element recordEle = (Element) iter.next();  
  104.                 String title = recordEle.elementTextTrim("title"); // 拿到head节点下的子节点title值  
  105.                 System.out.println("title:" + title);  
  106.                 map.put("title", title);  
  107.   
  108.                 Iterator iters = recordEle.elementIterator("script"); // 获取子节点head下的子节点script  
  109.   
  110.                 // 遍历Header节点下的Response节点  
  111.                 while (iters.hasNext()) {  
  112.   
  113.                     Element itemEle = (Element) iters.next();  
  114.   
  115.                     String username = itemEle.elementTextTrim("username"); // 拿到head下的子节点script下的字节点username的值  
  116.                     String password = itemEle.elementTextTrim("password");  
  117.   
  118.                     System.out.println("username:" + username);  
  119.                     System.out.println("password:" + password);  
  120.                     map.put("username", username);  
  121.                     map.put("password", password);  
  122.   
  123.                 }  
  124.             }  
  125.   
  126.             Iterator iterss = rootElt.elementIterator("body"); ///获取根节点下的子节点body  
  127.             // 遍历body节点  
  128.             while (iterss.hasNext()) {  
  129.                 Element recordEless = (Element) iterss.next();  
  130.                 String result = recordEless.elementTextTrim("result"); // 拿到body节点下的子节点result值  
  131.                 System.out.println("result:" + result);  
  132.   
  133.                 Iterator itersElIterator = recordEless.elementIterator("form"); // 获取子节点body下的子节点form  
  134.                 // 遍历Header节点下的Response节点  
  135.                 while (itersElIterator.hasNext()) {  
  136.   
  137.                     Element itemEle = (Element) itersElIterator.next();  
  138.   
  139.                     String banlce = itemEle.elementTextTrim("banlce"); // 拿到body下的子节点form下的字节点banlce的值  
  140.                     String subID = itemEle.elementTextTrim("subID");  
  141.   
  142.                     System.out.println("banlce:" + banlce);  
  143.                     System.out.println("subID:" + subID);  
  144.                     map.put("result", result);  
  145.                     map.put("banlce", banlce);  
  146.                     map.put("subID", subID);  
  147.                 }  
  148.             }  
  149.         } catch (DocumentException e) {  
  150.             e.printStackTrace();  
  151.         } catch (Exception e) {  
  152.             e.printStackTrace();  
  153.         }  
  154.         return map;  
  155.     }  
  156.   
  157.     public static void main(String[] args) {  
  158.   
  159.         // 下面是需要解析的xml字符串例子  
  160.         String xmlString = "<html>" + "<head>" + "<title>dom4j解析一个例子</title>"  
  161.                 + "<script>" + "<username>yangrong</username>"  
  162.                 + "<password>123456</password>" + "</script>" + "</head>"  
  163.                 + "<body>" + "<result>0</result>" + "<form>"  
  164.                 + "<banlce>1000</banlce>" + "<subID>36242519880716</subID>"  
  165.                 + "</form>" + "</body>" + "</html>";  
  166.   
  167.         /* 
  168.          * Test2 test = new Test2(); test.readStringXml(xmlString); 
  169.          */  
  170.         Map map = readStringXmlOut(xmlString);  
  171.         Iterator iters = map.keySet().iterator();  
  172.         while (iters.hasNext()) {  
  173.             String key = iters.next().toString(); // 拿到键  
  174.             String val = map.get(key).toString(); // 拿到值  
  175.             System.out.println(key + "=" + val);  
  176.         }  
  177.     }  
  178.   
  179. }  



这里遍历了所有的子项。但是实际应用中,我们不需要遍历所有的子节点。如果路径到达三层,那么解析起来就十分烦躁了。dom4j可以指定路径,省去中间的遍历。

[java] view plaincopy
  1. String xml ;//采用字符串初始化Document。如果是普通文件,可以采用上述代码中的方法。  
  2.   
  3. Document   document = DocumentHelper.parseText(xml);  
  4.   
  5. List<Element> targetElements = document.selectNodes("//head/sub/target");//直接得到target的Element 的列表,省去中间的查找,判断。  

dom4j还是很强大的,以后要多用用。
0 0