java中使用dom4j解析XML文件的方法教程

前言

dom4j是一个java的XML api,性能优异、功能强大、易于使用。以前听说过来解析xml文件的几种标准方式;但是从来的没有应用过来,所以可以在google中搜索dmo4j解析xml文件的方式,学习一下dom4j解析xml的具体操作。下面话不多说了,来一起看看详细的介绍吧

官网下载Dom4j地址:https://dom4j.github.io/

注意:使用Dom4j开发,需下载dom4j相应的jar文件

题目:后台利用dom4j解析student.xml文件,并返回List<Student>集合

需要解析的XML:

<?xml version="1.0" encoding="UTF-8"?>
<classes>
 <class name="ST01">
 <student id="10001">user1</student>
 <student id="10002">user2</student>
 <student id="10003">user3</student>
 </class>
 <class name="ST02">
 <student id="10004">user4</student>
 <student id="10005">user5</student>
 <student id="10006">user6</student>
 </class>
 <class name="ST03">
 <student id="10007">user7</student>
 <student id="10008">user8</student>
 <student id="10009">user9</student>
 </class>
 <class name="ST04">
 <student id="10010">user10</student>
 <student id="10011">user12</student>
 <student id="10012">user13</student>
 </class>
 <class name="ST05">
 <student id="10013">user14</student>
 <student id="10014">user15</student>
 <student id="10015">user16</student>
 </class>
</classes>

java解析xml代码:

/**
 * @author hh
 */
public class XmlUtil {
 /**
 * 读取xml学生列表信息
 * @return
 */
 public List<Student> listStudent(){
 //创建SAXReader对象
 SAXReader reader=new SAXReader();
 Document document = null;
 try {
  //通过read方法读取一个文件 转换成Document对象
  document = reader.read(new File("/Users/mac/Documents/students.xml"));
 } catch (DocumentException e) {
  e.printStackTrace();
 }
 //获取根节点元素对象
 Element node = document.getRootElement();
 return elementMethod(node);
 }

 /**
 * 获取节点中的信息
 * @param node
 * @return
 */
 private List<Student> elementMethod(Element node){
 List<Student> list = new ArrayList<Student>();
 //获取所有class 节点
 List<Element> elementClass = node.elements("class");
 for (Element aClass : elementClass) {
  //获取所有student节点
  List<Element> elelmentStu=aClass.elements("student");
  for (Element element : elelmentStu) {
  //创建学生对象
  Student stu = new Student();
  //class节点里name的值
  stu.setSclazz(aClass.attribute("name").getValue());
  //student节点里ID的值
  stu.setSid(element.attribute("id").getValue());
  //student节点里的String值
  stu.setSname(element.getStringValue());

  list.add(stu);
  }
 }

 return list;
 }
}

实体类:

/**
 * @author hh
 */
public class Student {
 private String sname;
 private String sid;
 private String sclazz;

 public String getSname() {
 return sname;
 }

 public void setSname(String sname) {
 this.sname = sname;
 }

 public String getSid() {
 return sid;
 }

 public void setSid(String sid) {
 this.sid = sid;
 }

 public String getSclazz() {
 return sclazz;
 }

 public void setSclazz(String sclazz) {
 this.sclazz = sclazz;
 }

 @Override
 public String toString() {
 return "Student{" +
  "sname='" + sname + '\'' +
  ", sid='" + sid + '\'' +
  ", sclazz='" + sclazz + '\'' +
  '}';
 }
}

@Test 代码:

public class StudentDaoTest {
 @Test
 public void testlistStudent(){
 List<Student> list = new XmlUtil().listStudent();
 for (Student student : list) {
  System.out.println(student);
 }
 }
}

运行结果:

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对我们的支持。

时间: 2018-09-08

Java生成和解析XML格式文件和字符串的实例代码

1.基础知识: Java解析XML一般有四种方法:DOM.SAX.JDOM.DOM4J. 2.使用介绍 1).DOM (1)简介 由W3C(org.w3c.dom)提供的接口,它将整个XML文档读入内存,构建一个DOM树来对各个节点(Node)进行操作.优点就是整个文档都一直在内存中,我们可以随时访问任何节点,并且对树的遍历也是比较熟悉的操作:缺点则是耗内存,并且必须等到所有的文档都读入内存才能进行处理. (2)示例代码: 复制代码 代码如下: <?xml version="1.0&quo

java 值Document解析xml详细介绍

java 值Document解析xml详细介绍 使用jar包:jdom.jar 配置文件格式 global.xml 一.获取输入的值组成的结点 我们将每个结点使用"." 拼接起来, 如结点i ,拼接为abc.def.i, 注意不包含root.解析每个结点的名字. /** * 获取对应结点的名字 * @param name 不包含root结点的拼接,ie: abc.def.i * @return */ private String[] parsePropertyName(String n

java使用xpath解析xml示例分享

XPath即为XML路径语言(XML Path Language),它是一种用来确定XML文档中某部分位置的语言.XPath基于XML的树状结构,提供在数据结构树中找寻节点的能力.起初 XPath 的提出的初衷是将其作为一个通用的.介于XPointer与XSL间的语法模型.但是 XPath 很快的被开发者采用来当作小型查询语言. XPathTest.java 复制代码 代码如下: package com.hongyuan.test; import java.io.File;import java

java解析XML几种方式小结

java解析XML几种方式小结 第一种:DOM. DOM的全称是Document Object Model,也即文档对象模型.在应用程序中,基于DOM的XML分析器将一个XML文档转换成一个对象模型的集合(通常称DOM树),应用程序正是通过对这个对象模型的操作,来实现对XML文档数据的操作.通过DOM接口,应用程序可以在任何时候访问XML文档中的任何一部分数据,因此,这种利用DOM接口的机制也被称作随机访问机制. DOM接口提供了一种通过分层对象模型来访问XML文档信息的方式,这些分层对象模型依

java实现简单解析XML文件功能示例

本文实例讲述了java实现简单解析XML文件功能.分享给大家供大家参考,具体如下: package demo; import java.io.File; import java.io.IOException; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.parsers.ParserConfigurationException;

Java解析调用webservice服务的返回XML串详解

本文由Markdown语法编辑器编辑完成. 1. 需求分析: 已知当在调用某一webservice的服务时,如果调用成功,会接受到该服务的返回XML串.后端在获取了该XML原始串时,需要进行解析,将其解析为JSON格式,以便于发送到前台,供前台页面显示和交互. 2. 解决方案: 该XML的原始形式为: <?xml version="1.0" encoding="UTF-8" ?> <SOAP-ENV:Envelope xmlns:SOAP-ENV=

java中利用Dom4j解析和生成XML文档

一.前言 dom4j是一套非常优秀的Java开源api,主要用于读写xml文档,具有性能优异.功能强大.和非常方便使用的特点.   另外xml经常用于数据交换的载体,像调用webservice传递的参数,以及数据做同步操作等等,   所以使用dom4j解析xml是非常有必要的. 二.准备条件 dom4j.jar 下载地址:http://sourceforge.net/projects/dom4j/ 三.使用Dom4j实战 1.解析xml文档 实现思路: <1>根据读取的xml路径,传递给SAX

java解析XML Node与Element的区别(推荐)

对Element和Node有困惑是因为对xml整个结构不了解,以下作为一个简要概述: 以下图为w3c.org网站的xml文档树图: 从上图可以看出,一个xml文档由元素节点,属性节点,文本节点构成,其中bookstore被称为文档元素或根元素,也是一个元素节点 XML DOM是这样规定一个节点的 XML 文档中的每个成分都是一个节点. 整个文档是一个文档节点    即Document节点.在java中Document接口是继承于Node接口,表示整个XML 文档 每个 XML 标签是一个元素节点

Java 解析XML数据的4种方式

解析的四种方式 DOM 解析 SAX 解析 JDOM 解析 DOM4J 解析 案例实操 DOM 解析 DOM(Document Object Model, 文档对象模型),在应用程序中,基于 DOM 的 XML 分析器将一个 XML 文档转换成一个对象模型的集合(通常称为 DOM 树 ),应用程序正是通过对这个对象模型的操作,来实现对 XML 文档数据的操作.XML 本身是以树状的形式出现的,所以 DOM 操作的时候,也将按章树的形式进行转换.在整个 DOM 树中,最大的地方指的是 Docume

Java解析XML的四种方法详解

XML现在已经成为一种通用的数据交换格式,它的平台无关性,语言无关性,系统无关性,给数据集成与交互带来了极大的方便.对于XML本身的语法知识与技术细节,需要阅读相关的技术文献,这里面包括的内容有DOM(Document Object Model),DTD(Document Type Definition),SAX(Simple API for XML),XSD(Xml Schema Definition),XSLT(Extensible Stylesheet Language Transform

详解Java解析XML的四种方法

XML现在已经成为一种通用的数据交换格式,它的平台无关性,语言无关性,系统无关性,给数据集成与交互带来了极大的方便.对于XML本身的语法知识与技术细节,需要阅读相关的技术文献,这里面包括的内容有DOM(Document Object Model),DTD(Document Type Definition),SAX(Simple API for XML),XSD(Xml Schema Definition),XSLT(Extensible Stylesheet Language Transform

java解析xml汇总_动力节点Java学院整理

[引言] 目前在Java中用于解析XML的技术很多,主流的有DOM.SAX.JDOM.DOM4j,下文主要介绍这4种解析XML文档技术的使用.优缺点及性能测试. 一.[基础知识--扫盲] sax.dom是两种对xml文档进行解析的方法(没有具体实现,只是接口),所以只有它们是无法解析xml文档的:jaxp只是api,它进一步封装了sax.dom两种接口,并且提供了DomcumentBuilderFactory/DomcumentBuilder和SAXParserFactory/SAXParser

java解析xml的4种方式的优缺点对比及实现详解

一.介绍及优缺点分析 DOM(Document Object Model) DOM是用与平台和语言无关的方式表示XML文档的官方W3C标准.DOM是以层次结构组织的节点或信息片断的集合.这个层次结构允许开发人员在树中寻找特定信息.分析该结构通常需要加载整个文档和构造层次结构,然后才能做任何工作.由于它是基于信息层次的,因而DOM被认为是基于树或基于对象的. [优点] ①允许应用程序对数据和结构做出更改. ②访问是双向的,可以在任何时候在树中上下导航,获取和操作任意部分的数据. 整个文档树在内存中

Java解析xml的四种方法汇总

1. DOM(JAXP Crimson解析器) DOM是用与平台和语言无关的方式表示XML文档的官方W3C标准.DOM是以层次结构组织的节点或信息片断的集合.这个层次结构允许开发人员在树中寻找特定信息.分析该结构通常需要加载整个文档和构造层次结构,然后才能做任何工作.由于它是基于信息层次的,因而DOM被认为是基于树或基于对象的.DOM以及广义的基于树的处理具有几个优点.首先,由于树在内存中是持久的,因此可以修改它以便应用程序能对数据和结构作出更改.它还可以在任何时候在树中上下导航,而不是像SAX

Java解析XML格式数据的方法详解

最初,XML 语言仅仅是意图用来作为 HTML 语言的替代品而出现的,但是随着该语言的不断发展和完善,人们越来越发现它所具有的优点:例如标记语言可扩展,严格的语法规定,可使用有意义的标记,内容存储和表现分离等等优势注定了该语言从诞生之日起就会走向辉煌. XML 语言在成为 W3C 标准之后进入到了一个快速发展的时期,当然它本身所具有的一系列优点和优势也注定了各大技术厂商对它的偏爱,Java 作为软件行业的一种开发技术也迅速作出了反应,出现了多种对 XML 支持的工具,本文将会从这个角度对 Jav

java解析xml常用的几种方式总结

各种方法都用过.现在总结一下. 经常记不住,要找资料.现在总结一下. xml 文件如下: 复制代码 代码如下: <?xml version="1.0" encoding="ISO-8859-1"?><bookstore><book category="COOKING">  <title lang="en">Everyday Italian</title>  <a