打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
使用Dom4j解析XML
package com.example;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; import org.junit.Test; public class Demo01 { @Test public void createXMLDemo() throws Exception { // 创建saxReader对象 SAXReader reader = new SAXReader(); // 通过read方法读取一个文件 转换成Document对象 Document document = reader.read(new File('src/car.xml')); //获取根节点元素对象 Element node = document.getRootElement(); //遍历所有的元素节点 // listNodes(node); elementMethod(node); } @Test public void readXMLDemo() throws Exception { Document document = DocumentHelper.createDocument(); Element root = document.addElement( 'cars' ); Element supercarElement= root.addElement('supercars') .addAttribute('company', 'Ferrai'); supercarElement.addElement('carname') .addAttribute('type', 'Ferrari 101') .addText('Ferrari 101'); supercarElement.addElement('carname') .addAttribute('type', 'sports') .addText('Ferrari 202'); // 写入到一个新的文件中 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//car.xml')), 'UTF-8'), format); // 写入 writer.write(document); // 立即写入 writer.flush(); // 关闭操作 writer.close(); } /** * 遍历当前节点元素下面的所有(元素的)子节点 * * @param node */ public void listNodes(Element node) { System.out.println('当前节点的名称::' + node.getName()); // 获取当前节点的所有属性节点 List 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 it = node.elementIterator(); // 遍历 while (it.hasNext()) { // 获取某个子节点对象 Element e = it.next(); // 对子节点进行遍历 listNodes(e); } } /** * 介绍Element中的element方法和elements方法的使用 * * @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 carnames = e.elements('carname'); for (Element cname : carnames) { System.out.println(cname.getText()); } // 获取supercars这个元素节点 所有元素的子节点。 List elements = e.elements(); for (Element el : elements) { System.out.println(el.getText()); } } }
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
XML in .NET: .NET Framework XML Classes and C...
Dom4j解析和生成XML文档
Java解析XML文档――dom解析xml
XML代码-如何使用DOM解析xml,打印xml文档信息工具类
JAXP(Java API for XML Parsing)
Java解析XML汇总(DOM/SAX/JDOM/DOM4j/XPath)
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服