DOM4J是 dom4j.org 出品的一个开源 XML 解析包。DOM4J应用于 Java 平台,采用了 Java 集合框架并完全支持 DOM,SAX 和 JAXP。DOM4J 使用起来非常简单。只要你了解基本的 XML-DOM 模型,就能使用。
1、读取XML文档:
SAXReader saxReader = new SAXReader();//读取XML要注意编码,是utf8Document document = saxReader.read(new FileInputStream("D:\aaa.xml"),"UTF-8");
2、与节点相关的操作:
//获取文档的根节点. Element rootElm = document.getRootElement(); //取得某节点的单个子节点. Element memberElm=root.element("member");// "member"是节点名 //取得节点的文字 String text=memberElm.getText(); String text=root.elementText("name");这个是取得根节点下的name字节点的文字. //取得某节点下指定名称的所有节点并进行遍历. List nodes = rootElm.elements("member"); for (Iterator it = nodes.iterator(); it.hasNext();) { Element elm = (Element) it.next(); // do something } //某节点下添加子节点. Element ageElm = newMemberElm.addElement("age"); //修改节点文字. ageElm.setText("29"); //删除某节点. parentElm.remove(childElm); // childElm是待删除的节点,parentElm是其父节点 //添加一个CDATA节点. Element contentElm = infoElm.addElement("content"); contentElm.addCDATA(diary.getContent());
3、与属性相关的操作:
//取得节点的指定的属性 Element root=document.getRootElement(); Attribute attribute=root.attribute("size"); // 属性名size //取得属性的名字和值 String text=attribute.getText(); String text1=attribute.getValue();//取得属性的值 String text2=root.element("name").attributeValue("firstname");//这个是取得根节点下name字节点的firstname属性的值. //遍历某节点的所有属性 Element root=document.getRootElement();for(Iterator it=root.attributeIterator();it.hasNext();){Attribute attribute = (Attribute) it.next();String text=attribute.getText();System.out.println(text);}//添加加某节点的属性和文字. newMemberElm.addAttribute("name", "sitinspring"); //修改属性的文字 Attribute attribute=root.attribute("name"); attribute.setText("sitinspring"); //修改属性的值 attribute.setValue("tom"); //删除某属性 Attribute attribute=root.attribute("size");// 属性名name root.remove(attribute);
4、将文档写入XML文件:
OutputFormat out = new OutputFormat(" ",true);out.setEncoding("UTF-8"); XMLWriter xml = new XMLWriter(new FileOutputStream("D:\aaa.xml"),out);xml.write(document);xml.flush();xml.close();System.out.println("新的XML文件生成成功");