<?xml version="1.0" encoding="UTF-8"?>
<书架>
   
  <书 出版日期="2013-10-25" 出版社="人民出版社" 编号="b1">
       <作者>曾哥</作者>
      <作者>东方不败</作者>
      <售价>66.8</售价>
      <简介>欲练此功,不必自宫!</简介>
      <书名>
       <bookmark>辟邪剑谱</bookmark>
      </书名>
      <书名>葵花宝典</书名>
   </书>
  
   <书 出版社="清华出版社" 编号="b2">
      <书名 ID="b1" value="hahaha">九阴真经</书名>
      <作者>独孤求败</作者>
      <售价>88.9</售价>
      <简介>武功狠!!!</简介>
   </书>
</书架>
用递归将想找的标签名中的文本值找到:
package myTestDom4j;
import java.util.List;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
public class MyDom4jZSGC {
     
   public static void main(String[] args) throws DocumentException {
    SAXReader reader = new SAXReader();
    Document document = reader.read("src/main/resources/book.xml");
    Element rootElement = document.getRootElement(); //拿到跟节点<书架>
    List<Element> elementList = rootElement.elements(); //<书架>的两个儿子
testSelect(elementList);
}
private static void testSelect(List<Element> elementList4) throws DocumentException {
    int nums = elementList4.size();
    for (int i = 0; i < nums; i++) {
       Element elementEvery = elementList4.get(i);     //<书架>的第一个儿子
       List<Element> elementEverySun = elementEvery.elements();//<书架>的两个儿子的后背所有节点
   
       if (elementEverySun.size() == 0) {
          if (elementEvery.getName().equals("bookmark")) {
           System.out.println(elementEvery.getText());
          }
       } else {
           testSelect(elementEverySun);
       }
     }
    }
 }
原文:http://www.cnblogs.com/yinlixin/p/4606061.html