新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
小编给大家分享一下XML解析之DOM4J解析的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
创新互联主营玉泉网站建设的网络公司,主营网站建设方案,app软件开发,玉泉h5微信小程序搭建,玉泉网站营销推广欢迎玉泉等地区企业咨询
关于XML的解析方式有好多种,DOM、SAX、JDOM等等,至于用法和原理这里就不在说了(ps:楼主也不知道用法和原理)。这篇文章主要说说DOM4J的简单操作和用法。
DOM4J介绍
dom4j是一个Java的XML API,是jdom的升级品,用来读写XML文件的。dom4j是一个十分优秀的JavaXML API,具有性能优异、功能强大和极其易使用的特点,它的性能超过sun公司官方的dom技术,同时它也是一个开放源代码的软件,可以在SourceForge上找到它。
Dom4j是一个易用的、开源的库,用于XML,XPath和XSLT。它应用于Java平台,采用了Java集合框架并完全支持DOM,SAX和JAXP。
这里用一个简单的例子来介绍DOM4J的用法。
注意:使用DOM4J解析XML,需要在项目中引入DOM4J的jar包
XML文件
图片1 图片2 图片3
DOM4J使用详解
步骤1:加载xml文件
加载xml可以分为主要的两种方式
1、直接加载文件所在的路径地址
2、加载字符串形式的xml(此方式主要是用在服务器返回结果中)
1.1、直接加载文件路径
SAXReader reader = new SAXReader(); Document document = null; try { document = reader.read(new File("E://CZBK//day01//caseUp.xml")); } catch (DocumentException e) { e.printStackTrace(); }
1.2、加载字符串形式的xml
SAXReader reader = new SAXReader(); Document document = null; try { //result是需要解析的字符串 //解析字符串需要转换成流的形式,可以指定转换字符编码 document = reader.read(new ByteArrayInputStream(result.getBytes("UTF-8"))); } catch (DocumentException e) { e.printStackTrace(); }
步骤2:解析XML
在解析XML之前,我们先来介绍下XML的结构称呼,清楚下面4个问题对解析XML很有帮助
什么是节点(node)?什么是元素(element)?什么是属性(attribute)?什么是文本值(value)?
节点:“Response”、“Media”这些称之为节点
元素:以一个完整的标签结束称之为元素,包含整个元素内容。例如:
属性:节点的属性值,对节点内容加之说明。例如:T='203' T1='6' TaskID='20130800001963' MediaNum='3' Result = '1' Desc='查询成功!'
文本值:“图片1”称之为文本值。
在项目中无非就是围绕元素、属性和文本值进行操作,所以掌握好这三部分的取值方法,也就掌握了XML解析。
2.1、获取根节点
//获取整个文档 Element rootElement = document.getRootElement();
rootElement包含整个xml文档的内容,也就是Response标签包含的所有内容
2.2、获取Response节点的属性值
//获取Response节点的Result属性值 String responseResult = rootElement.attributeValue("Result");
2.3、获取Media元素
//获取第一个Media元素 Element mediaElement = rootElement.element("Media"); //获取所有的Media元素 List allMeidaElements = rootElement.elements("Media");
2.4、获取Media属性值
//获取第一个Media元素的Name属性值 String mediaName = mediaElement.attributeValue("Name"); //遍历所有的Media元素的Name属性值 for (int i = 0; i < allMeidaElements.size(); i++) { Element element = (Element) allMeidaElements.get(i); String name = element.attributeValue("Name"); }
2.5、获取Media标签的文本值
//获取第一个Meida元素的文本值 String value = mediaElement.getText();
完整代码
import java.io.File; import java.util.List; import org.dom4j.Document; import org.dom4j.DocumentException; import org.dom4j.Element; import org.dom4j.io.SAXReader; public class Textxml { public void xml() { SAXReader reader = new SAXReader(); Document document = null; try { document = reader.read(new File("E://CZBK//day01//caseUp.xml")); } catch (DocumentException e) { e.printStackTrace(); } //获取整个文档 Element rootElement = document.getRootElement(); System.out.println("整个文档:"+rootElement.asXML()); //获取Response节点的Result属性值 String responseResult = rootElement.attributeValue("Result"); System.out.println("Response节点的Result属性值:"+responseResult); //获取第一个Media元素 Element mediaElement = rootElement.element("Media"); System.out.println("第一个Media元素:"+mediaElement.asXML()); //获取所有的Media元素 List allMeidaElements = rootElement.elements("Media"); //获取第一个Media元素的Name属性值 String mediaName = mediaElement.attributeValue("Name"); System.out.println("第一个Media元素的Name属性值:"+mediaName); //遍历所有的Media元素的Name属性值 for (int i = 0; i < allMeidaElements.size(); i++) { Element element = (Element) allMeidaElements.get(i); String name = element.attributeValue("Name"); } //获取第一个Meida元素的文本值 String value = mediaElement.getText(); System.out.println("第一个Meida元素的文本值:"+value); } public static void main(String[] args) { Textxml textxml = new Textxml(); textxml.xml(); } }
运行结果
整个文档:Response节点的Result属性值:1 第一个Media元素: 图片1 图片2 图片3 图片1 第一个Media元素的Name属性值:IMG_20130425_141838.jpg 第一个Meida元素的文本值:图片1
以上是“XML解析之DOM4J解析的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!