1、导入jar包,dom4j.jar包
2、XML代码如下:一个根元素,两个子元素
<?xml version="1.0" encoding="UTF-8"?>
<zky>
<go>1</go>
<to weight="5" height="2.5">age</to>
</zky>
3、新建一个java类,作用是读取xml文件根元素:
package org.sie.research.xml;
import com.sun.xml.internal.bind.v2.runtime.output.NamespaceContextImpl;
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
import org.w3c.dom.Attr;
import java.util.Iterator;
public class XmlParser {
public static void main(String[] args) {
//(1)生成SAXReader对象
SAXReader saxReader=new SAXReader();
try {
//(2)获取Document对象
Document document=saxReader.read("src/org/sie/research/xml/SqlMapConfig.xml");
//(3)获取根元素
Element el_root=document.getRootElement();
//(4)根据根元素遍历子元素
//(4.1)获取根元素的迭代器
Iterator<Element> iter_Root=el_root.elementIterator();
//(4.2)使用根元素的迭代器找出子元素
Element el_sub=null;
Attribute el_attr=null;
while(iter_Root.hasNext()){
el_sub= iter_Root.next();
System.out.println("子元素的标签:"+el_sub.getName());//子元素的标签
System.out.println("子元素的文本:"+el_sub.getText());//子元素的文本
//(5)如果元素有属性的话,也把属性遍历出来
//(5.1)首先获取属性迭代器
Iterator<Attribute> el_attr_iter=el_sub.attributeIterator();
while(el_attr_iter.hasNext()){
el_attr=el_attr_iter.next();
System.out.println("属性的名字:"+el_attr.getName());//输出属性的名字
System.out.println("属性的值:"+el_attr.getValue());//输出属性的值
}
}
//根据el_root.getName()获取根元素的名字
//System.out.println(el_root.getName());
} catch (DocumentException e) {
e.printStackTrace();
}
}
}