关于dom4j在maven中的使用
在maven中添加dom4j的依赖, (如何使用eclipse构建maven项目, 这里就不在赘述)
<!-- https://mvnrepository.com/artifact/org.dom4j/dom4j --> <dependency> <groupId>org.dom4j</groupId> <artifactId>dom4j</artifactId> <version>2.0.0</version> </dependency>
这里指的注意的是, 如果引入的版本较低, 可能不能使用dom4j的包, 我之前引入的是1.6.1版本, 就是提示不能用, 后来经过分析, 断定是引入版本过低导致。
下面是个人测试使用的案例, 大家可以直接拷贝使用, 使用工具是eclipse.
package com.test; import java.io.File; import java.io.FileOutputStream; import java.io.OutputStreamWriter; import java.util.Iterator; import java.util.List; import org.dom4j.Attribute; import org.dom4j.Document; import org.dom4j.DocumentHelper; import org.dom4j.Element; import org.dom4j.io.OutputFormat; import org.dom4j.io.SAXReader; import org.dom4j.io.XMLWriter; /* * DOM4J类 DOM4J定义了几个Java类。以下是最常见的类: Document - 表示整个XML文档。文档Document对象是通常被称为DOM树。 Element - 表示一个XML元素。 Element对象有方法来操作其子元素,它的文本,属性和名称空间。 Attribute - 表示元素的属性。属性有方法来获取和设置属性的值。它有父节点和属性类型。 Node - 代表元素,属性或处理指令 常见DOM4J的方法 当使用DOM4J,还有经常用到的几种方法: SAXReader.read(xmlSource)() - 构建XML源的DOM4J文档。 Document.getRootElement() - 得到的XML的根元素。 Element.node(index) - 获得在元素特定索引XML节点。 Element.attributes() - 获取一个元素的所有属性。 Node.valueOf(@Name) - 得到元件的给定名称的属性的值。 * * */ public class ParseXml { public void readXML() throws Exception { // 创建saxReader对象 SAXReader reader = new SAXReader(); // 通过read方法读取一个文件 转换成Document对象 Document document = reader.read(new File("src/test1.xml")); // 获取根节点元素对象 Element node = document.getRootElement(); // 遍历所有的元素节点 listNodes(node); elementMethod(node); } public void createXML() throws Exception { Document document = DocumentHelper.createDocument(); Element root = document.addElement("cars"); Element supercarElement = root.addElement("supercars").addAttribute("company", "Ferrai"); supercarElement.addElement("carname").addAttribute("type", "FerrariAttr").addText("FerrariText"); supercarElement.addElement("carname").addAttribute("type", "sportsAttr").addText("sportsText"); // 写入到一个新的文件中 writer(document); } /** * 把document对象写入新的文件 * * @param document * @throws Exception */ public void writer(Document document) throws Exception { // 紧凑的格式 // OutputFormat format = OutputFormat.createCompactFormat(); // 排版缩进的格式 OutputFormat format = OutputFormat.createPrettyPrint(); // 设置编码 format.setEncoding("UTF-8"); // 创建XMLWriter对象,指定了写出文件及编码格式 // XMLWriter writer = new XMLWriter(new FileWriter(new // File("src//a.xml")),format); XMLWriter writer = new XMLWriter( new OutputStreamWriter(new FileOutputStream(new File("src//test1.xml")), "UTF-8"), format); // 写入 writer.write(document); // 立即写入 writer.flush(); // 关闭操作 writer.close(); } /** * 遍历当前节点元素下面的所有(元素的)子节点 * * @param node */ public void listNodes(Element node) { System.out.println("当前节点的名称::" + node.getName()); // 获取当前节点的所有属性节点 List<Attribute> list = node.attributes(); // 遍历属性节点 for (Attribute attr : list) { System.out.println(attr.getText() + "-----" + 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); } } /** * * @param node */ public void elementMethod(Element node) { // 获取node节点中,子节点的元素名称为supercars的元素节点。 Element e = node.element("supercars"); // 获取supercars元素节点中,子节点为carname的元素节点(可以看到只能获取第一个carname元素节点) Element carname = e.element("carname"); System.out.println(e.getName() + "----" + carname.getText()); // 获取supercars这个元素节点 中,所有子节点名称为carname元素的节点 。 List<Element> carnames = e.elements("carname"); for (Element cname : carnames) { System.out.println(cname.getText()); } // 获取supercars这个元素节点 所有元素的子节点。 List<Element> elements = e.elements(); for (Element el : elements) { System.out.println(el.getText()); } } }
努力做一个伪程序员, 不管道路有多么的艰苦......
posted on 2018-03-30 21:17 努力做一个伪程序员 阅读(22355) 评论(0) 编辑 收藏 举报