您的位置:首页 > 其它

DOM4J XML解析

2016-07-18 01:18 225 查看
方法一:

例如有这么一个xml文件data4.xml

<?xml version="1.0" encoding="UTF-8"?>
<aaaa>
<bbbb>
<cccc>
<dddd>
<username>aaa</username>
</dddd>
<dddd>
<username>bbb</username>
</dddd>
</cccc>
</bbbb>
</aaaa>

总共有4层,我们的目标是读取到username

package wzq.j2se.xml;

import java.util.Iterator;

import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
import org.xml.sax.InputSource;

public class Dom4j4 {
public static void main(String[] args) {
try{
InputSource is = new InputSource("http://localhost/data4.xml");
SAXReader reader = new SAXReader();   
reader.setEncoding("utf-8");
/*File f = new File("D:\\androidspace\\javanote\\src\\wzq\\j2se\\xml\\data4.xml");  
Document doc = reader.read(f); */
Document doc = reader.read(is);
Dom4j4 j1 = new Dom4j4();
Element rootElt = doc.getRootElement(); // 获取根节点
        System.out.println("根节点:" + rootElt.getName()); // 拿到根节点的名称
        Iterator bbbb = rootElt.elementIterator("bbbb"); ///获取根节点下的子节点bbbb
           // 遍历bbbb节点
           while (bbbb.hasNext()) {
               Element recordEless = (Element) bbbb.next();
               Iterator cccc = recordEless.elementIterator("cccc"); // 获取子节点bbbb下的子节点cccc
               while (cccc.hasNext()) {
                   Element itemEle = (Element) cccc.next();
                   Iterator dddd = itemEle.elementIterator("dddd");
                   while(dddd.hasNext()){
                    Element tableItem = (Element) dddd.next();
                    String username = tableItem.elementTextTrim("username"); // 拿到dddd下的字节点username的值
                   System.out.println("username:" + username);
                   }
               }
           }
}catch(Exception e){
e.printStackTrace();
}
}
}

方法二:
<?xml version="1.0" encoding="UTF-8"?>  
<root>  
    <user editor="chenleixing" date="2015-02-15">  
        <name>张三</name>  
        <year>24</year>  
        <sex>男</sex>  
    </user>  
    <user editor="zhangxiaochao" date="2015-02-15">  
        <name>李四</name>  
        <year>24</year>  
        <sex>女</sex>  
    </user>  
</root> 

       /** 
 * 获取文件的document对象,然后获取对应的根节点 
 * @author chenleixing 
 */  
@Test  
public void testGetRoot() throws Exception{  
    SAXReader sax=new SAXReader();//创建一个SAXReader对象  
    File xmlFile=new File("d:\\test.xml");//根据指定的路径创建file对象  
    Document document=sax.read(xmlFile);//获取document对象,如果文档无节点,则会抛出Exception提前结束  
    Element root=document.getRootElement();//获取根节点  
    this.getNodes(root);//从根节点开始遍历所有节点  
  


[java]
view plain
copy

       /** 
 * 从指定节点开始,递归遍历所有子节点 
 * @author chenleixing 
 */  
public void getNodes(Element node){  
    System.out.println("--------------------");  
      
    //当前节点的名称、文本内容和属性  
    System.out.println("当前节点名称:"+node.getName());//当前节点名称  
    System.out.println("当前节点的内容:"+node.getTextTrim());//当前节点名称  
    List<Attribute> listAttr=node.attributes();//当前节点的所有属性的list  
    for(Attribute attr:listAttr){//遍历当前节点的所有属性  
        String name=attr.getName();//属性名称  
        String value=attr.getValue();//属性的值  
        System.out.println("属性名称:"+name+"属性值:"+value);  
    }  
      
    //递归遍历当前节点所有的子节点  
    List<Element> listElement=node.elements();//所有一级子节点的list  
    for(Element e:listElement){//遍历所有一级子节点  
        this.getNodes(e);//递归  
    }  
}

--------------------  
当前节点名称:root  
当前节点的内容:  
--------------------  
当前节点名称:user  
当前节点的内容:  
属性名称:editor属性值:chenleixing  
属性名称:date属性值:2015-02-15  
--------------------  
当前节点名称:name  
当前节点的内容:张三  
--------------------  
当前节点名称:year  
当前节点的内容:24  
--------------------  
当前节点名称:sex  
当前节点的内容:男  
--------------------  
当前节点名称:user  
当前节点的内容:  
属性名称:editor属性值:zhangxiaochao  
属性名称:date属性值:2015-02-15  
--------------------  
当前节点名称:name  
当前节点的内容:李四  
--------------------  
当前节点名称:year  
当前节点的内容:24  
--------------------  
当前节点名称:sex  
当前节点的内容:女
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: