|
Java编程中应用dom4j轻松地处理XML文档(1) dom4j是Java平台中一个简单易用的XML处理工具,它使用的是Java的Collections架构,提供了对DOM,SAX,JAXP的完整支持。
1.创建新的XML文档
import org.dom4j.Document; import org.dom4j.DocumentHelper; import org.dom4j.Element; public class Users { public Document createDocument() { Document document = DocumentHelper.createDocument(); Element root = document.addElement( "users" ); Element me = root.addElement( "user" ) .addAttribute( "userid", "sUCode" ) .addAttribute( "username", "Eric Yu" ) .addText( "myself" ); Element me = root.addElement( "user" ) .addAttribute( "userid", "scottl" ) .addAttribute( "username", "Scott Long" ) .addText( "FreeBSD leader" ); return document; } }
以上代码创建了如下的XML文档:
<users> <user userid="sucode" username="Eric Yu">myself</user> <user userid="scottl" username="Scott Long">FreeBSD leader</user> </users>
2.XML文档与字符串之间的相互转换
个人比较喜欢的一个dom4j特性就是它提供了非常简便的方法将XML文档转换为XML格式的字符串。由于Document,Element,Attribute都继承了Node接口,所以他们都提供了asXML()方法,该方法返回节点的XML格式描述。
Document document = (new Users()).createDocument(); String text = document.asXML();
而将XML字符串转换为Document同样非常简便:
Document doc = DocumentHelper.parseText(text);
3.快速遍历
如果需要处理很大的XML文档,为每个循环创建一个Iterator对象将带来很大的开销。这时候推荐使用快速遍历(fast Looping):
public void treeWalk(Document document) { treeWalk( document.getRootElement() ); } public void treeWalk(Element element) {
|