用dom4j怎么读取xml文档的注释

 我来答
杜爷1号
推荐于2016-05-10 · 知道合伙人软件行家
杜爷1号
知道合伙人软件行家
采纳数:4973 获赞数:9186
毕业于福建农林大学,本科学士学位。从事IT行业3年,曾参与过多个大型项目的需求调研、软件研发。

向TA提问 私信TA
展开全部
第一种:
/**
* 使用dom4j 中saxreader 获取Document容器,利用此容器的elementIterator读取xml文件
*/
public static void readXML() throws DocumentException{

SAXReader sr = new SAXReader();//获取读取xml的对象。
Document doc = sr.read("src/com/sinojava/EMP.xml");//得到xml所在位置。然后开始读取。并将数据放入doc中
Element el_root = doc.getRootElement();//向外取数据,获取xml的根节点。
Iterator it = el_root.elementIterator();//从根节点下依次遍历,获取根节点下所有子节点

while(it.hasNext()){//遍历该子节点

Object o = it.next();//再获取该子节点下的子节点
Element el_row = (Element)o;
String s = el_row.getText();
Iterator it_row = el_row.elementIterator();

while(it_row.hasNext()){//遍历节点

Element el_ename = (Element)it_row.next();//获取该节点下的所有数据。
System.out.println(el_ename.getText());
}
//System.out.println(o);
}

}

第二种

/**
* 使用elements方法进行xml的读取,相当于条件查询,可以根据不同的节点,利用for循环查询该节点下所有的数据。
* @throws DocumentException
*/
public static void readXML02() throws DocumentException{

SAXReader sr = new SAXReader();//获取读取方式
Document doc = sr.read("src/com/sinojava/EMP.xml");//读取xml文件,并且将数据全部存放到Document中
Element root = doc.getRootElement();//获取根节点

List list = root.elements("ROW");//根据根节点,将根节点下 row中的所有数据放到list容器中。
for(Object obj:list){//这种遍历方式,是jdk1.5以上的版本支持的遍历方式
Element row = (Element)obj;
List list_row = row.elements("ENAME");//获取ENAME节点下所有的内容,存入list_row容器中

for(Object objempno:list_row){

Element el_empno = (Element)objempno;

System.out.println(el_empno.getName()+": "+el_empno.getText());//获取节点下的数据。

}
}
}

第三种:
/**
* 使用适配器来完成xml的读取。
* @param args
* @throws DocumentException
*/
public static void readXML04() throws DocumentException{

SAXReader sr = new SAXReader();
Document doc = sr.read("src/com/sinojava/EMP.xml");

doc.accept(new VisitorSupport() {//使用观察器的子类,来完成对xml文件的读取。

public void visit(Element el) {//利用观察期进行xml的读取。

System.out.println(el.getName()+": "+el.getText());
}

});
}

第四种:
/**
* 使用selectNodes读取xml文件
* @param args
* @throws DocumentException
*/
public static void readXML05(String elementpath) throws DocumentException{

SAXReader sr = new SAXReader();
Document doc = sr.read("src/com/sinojava/EMP.xml");

List list = doc.selectNodes(elementpath);//使用selectNodes获取所要查询xml的节点。

for(Object obj:list){//遍历节点,获取节点内数据。

Element el = (Element)obj;
System.out.println(el.getText());
}

}

以上四种都是使用dom4j来读取xml文件。是比较常见的四种方式。当然还有其他的不用dom4j的方式。不过在此处我没有列出。如果有知道其他方式的朋友欢迎回帖。一起研究。
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式