dom4j解析xml文件

1 篇文章 0 订阅
1 篇文章 0 订阅

dom4j解析xml文件

  1.   dom4j是一个Java的XML API,类似于jdom,用来读写XML文件的。dom4j是一个非常非常优秀的Java XML API,具有性能优异、功能强大和极易用使用的特点,同时它也是一个开放源代码的软件,可以在SourceForge 上找到它.

        对主流的Java XML API进行的性能、功能和易用性的评测,dom4j无论在那个方面都是非常出色的。如今你可以看到越来越多的Java软件都在使用dom4j来读写XML,例如Hibernate,包括sun公司自己的JAXM也用 了Dom4j。

        官网下载: http://www.dom4j.org/dom4j-1.6.1    

  2. 以下为测试代码  
  3.  

    package xml; import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import java.io.OutputStreamWriter; import java.util.Iterator; import java.util.List; import org.dom4j.Attribute; import org.dom4j.Document; import org.dom4j.DocumentException; import org.dom4j.DocumentHelper; import org.dom4j.Element; import org.dom4j.io.OutputFormat; import org.dom4j.io.SAXReader; import org.dom4j.io.XMLWriter; /** * xml学习 * @author wangkj * */ public class xmlStudy { public static void main(String[] args) throws DocumentException, IOException { Document doc=getDocument(); if(null ==doc) return; Element root = doc.getRootElement(); if(null==root) return; //读取xml文件,遍历节点 long t1=System.currentTimeMillis(); listNodes(root); // elementMethod(root); // writeXml(doc); // strToXml(doc); long t2 = System.currentTimeMillis(); System.out.println(t2-t1); // createXml(); } /** * 获得Document对象的三种方式 * @return * @throws DocumentException */ public static Document getDocument() throws DocumentException{ Document doc=null; //读取xml文件,获得Document对象 SAXReader reader = new SAXReader(); // doc= reader.read(new File("src\\xml\\test.xml")); doc= reader.read(new File("src\\xml\\job1.xml")); // String txt=doc.asXML();//读取的xml装换为文本 // System.out.println(txt); //解析xml形式的文本,获得Document对象 // String xmlTxt = "<class></class>"; // doc = DocumentHelper.parseText(xmlTxt); //创建Document对象 // doc = DocumentHelper.createDocument(); // Element root = doc.addElement("root");//创建根节点 return doc; } /** * 读取xml文件,遍历当前节点下的所有子节点 * @param node */ @SuppressWarnings("unchecked") public static void listNodes(Element node){ System.out.println("当前节点的名称:"+node.getName()); //获取当前节点的所有属性节点 List<Attribute> list = node.attributes(); //遍历属性节点 for(Attribute attr:list){ System.out.println("属性:"+attr.getName() +"="+attr.getValue()); } //获得文本节点 if(!node.getTextTrim().equals("")) System.out.println("文本节点内容:"+node.getText()); //当前节点下子节点迭代器 Iterator<Element> it = node.elementIterator(); //遍历 while(it.hasNext()){ //获取某个子节点的对象 Element e = it.next(); //递归遍历 listNodes(e); } } /** * * Element中element()核elements()方法 * @param node */ public static void elementMethod(Element node){ //获取node节点中,子节点元素名称为college的元素节点(只能获取第一个college元素节点) Element e = node.element("college"); System.out.println(e.getName()); //获取college节点下,子节点元素名称为class的元素节点(第一个) e = e.element("class"); //获取class节点下,子节点元素名称为student的所有元素 List<Element> stus = e.elements("student"); for(Element stu:stus) System.out.println("第一个colleg节点下的第一个class节点下所有的节点元素的name属性值:"+stu.attributeValue("name")); //获取node节点下的所有元素的节点 List<Element> elements = node.elements(); for(Element ee:elements) System.out.println("根目录下的所有子元素的name属性值:"+ee.attributeValue("name")); } /** * 写xml文件 * @param doc * @throws IOException */ public static void writeXml(Document doc) throws IOException{ //紧凑格式 // OutputFormat format = OutputFormat.createCompactFormat(); //排版缩进格式 OutputFormat format = OutputFormat.createPrettyPrint(); //设置编码格式 format.setEncoding("UTF-8"); File file = new File("src\\xml\\test1.xml"); if(file.exists()) file.delete(); //制订了写出文件及编码格式 XMLWriter writer = new XMLWriter(new OutputStreamWriter(new FileOutputStream(file), "UTF-8"), format); //写入 writer.write(doc); //刷新立即写入 writer.flush(); //关闭流 writer.close(); } /** * 字符串和xml之间的转换 * @param doc * @throws DocumentException * @throws IOException */ public static void strToXml(Document doc) throws DocumentException, IOException{ //xml文档转换为字符串 String strXml = doc.asXML(); System.out.println(strXml); Element root = doc.getRootElement(); if(null == root) return; //xml根元素标签转换为字符串 String strRoot = root.asXML(); // System.out.println("root:"+strRoot); String txt ="<A>" +"<a index='1'></a>"+"<a index='2'>a2</a>"+"</A>"; //转换为文档对象 doc = DocumentHelper.parseText(txt); writeXml(doc); } /** * 创建Document对象,往doc对象中添加元素节点,转换为xml文件 * @throws IOException */ public static void createXml() throws IOException{ Document doc = DocumentHelper.createDocument(); Element root = doc.addElement("ROOT");//创建根节点 //在根节点下添加属性和子节点等。。 //添加属性 root.addAttribute("name", "root"); root.addComment("这是根节点."); Element child = root.addElement("child"); child.setText("文本内容。");//设置文本节点 child.setName("c");//设置节点的名称child--c writeXml(doc); } }

    2、xml测试文件

          

    <?xml version="1.0" encoding="UTF-8"?> <university name="pku"> <college name="c1"> <class name="class1" index="1"> <student name="stu1" sex='male' age="21" /> <student name="stu2" sex='female' age="20" /> <student name="stu3" sex='female' age="20" /> </class> <class name="class2"> <student name="stu4" sex='male' age="19" /> <student name="stu5" sex='female' age="20" /> <student name="stu6" sex='female' age="21" /> </class> </college> <college name="c2"> <class name="class3"> <student name="stu7" sex='male' age="20" /> </class> </college> <college name="c3"> </college> <manager name="m1">文本内容</manager> </university>



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值