Java中XML的四种解析方式(二)

三、JDOM解析

    特征:

      1、仅使用具体类,而不使用接口。

      2、API大量使用了Collections类。

 1 import org.jdom2.Attribute;
 2 import org.jdom2.Document;
 3 import org.jdom2.Element;
 4 import org.jdom2.JDOMException;
 5 import org.jdom2.input.*;
 6 import java.io.*;
 7 import java.util.ArrayList;
 8 import java.util.List;
 9
10 public class JDOMTest {
11     private static ArrayList<Book> booksList = new ArrayList<Book>();
12     public static void main(String[] args) {
13         // 进行对books.xml文件的JDOM解析
14         // 准备工作
15         // 1.创建一个SAXBuilder的对象
16         SAXBuilder saxBuilder = new SAXBuilder();
17         try {
18             // 2.创建一个输入流,将xml文件加载到输入流中
19             InputStream in = new FileInputStream("src/book.xml");
20             InputStreamReader isr = new InputStreamReader(in, "UTF-8");
21             // 3.通过saxBuilder的build方法,将输入流加载到saxBuilder中
22             Document document = saxBuilder.build(isr);
23             // 4.通过document对象获取xml文件的根节点
24             Element rootElement = document.getRootElement();
25             // 5.获取根节点下的子节点的List集合
26             List<Element> bookList = rootElement.getChildren();
27             // 继续进行解析
28             for (Element book : bookList) {
29                 Book bookEntity = new Book();
30                 System.out.println("======开始解析第" + (bookList.indexOf(book) + 1)
31                         + "书======");
32                 // 解析book的属性集合
33                 List<Attribute> attrList = book.getAttributes();
34                 // 知道节点下属性名称时,获取节点值
35                 // book.getAttributeValue("id");
36                 // 遍历attrList(针对不清楚book节点下属性的名字及数量)
37                 for (Attribute attr : attrList) {
38                     // 获取属性名
39                     String attrName = attr.getName();
40                     // 获取属性值
41                     String attrValue = attr.getValue();
42                     System.out.println("属性名:" + attrName + "----属性值:"
43                             + attrValue);
44                     if (attrName.equals("id")) {
45                         bookEntity.setId(attrValue);
46                     }
47                 }
48                 // 对book节点的子节点的节点名以及节点值的遍历
49                 List<Element> bookChilds = book.getChildren();
50                 for (Element child : bookChilds) {
51                     System.out.println("节点名:" + child.getName() + "----节点值:"
52                             + child.getValue());
53                     if (child.getName().equals("name")) {
54                         bookEntity.setName(child.getValue());
55                     }
56                     else if (child.getName().equals("author")) {
57                         bookEntity.setAuthor(child.getValue());
58                     }
59                     else if (child.getName().equals("year")) {
60                         bookEntity.setYear(child.getValue());
61                     }
62                     else if (child.getName().equals("price")) {
63                         bookEntity.setPrice(child.getValue());
64                     }
65                     else if (child.getName().equals("language")) {
66                         bookEntity.setLanguage(child.getValue());
67                     }
68                 }
69                 System.out.println("======结束解析第" + (bookList.indexOf(book) + 1)
70                         + "书======");
71                 booksList.add(bookEntity);
72                 bookEntity = null;
73                 System.out.println(booksList.size());
74                 System.out.println(booksList.get(0).getId());
75                 System.out.println(booksList.get(0).getName());
76
77             }
78         } catch (FileNotFoundException e) {
79             e.printStackTrace();
80         } catch (JDOMException e) {
81             e.printStackTrace();
82         } catch (IOException e) {
83             e.printStackTrace();
84         }
85     }
86 }
SAX解析开始
=========开始遍历某一本书的内容========
book元素的第1个属性名是:id
---属性值是:1
节点值是:冰与火之歌
节点名是:author---节点值是:乔治马丁
节点名是:year---节点值是:2014
节点名是:price---节点值是:89
===========结束遍历某一本书的内容===========
=========开始遍历某一本书的内容========
book元素的第1个属性名是:id
---属性值是:2
节点值是:安徒生童话
节点名是:year---节点值是:2004
节点名是:price---节点值是:77
节点名是:language---节点值是:English
===========结束遍历某一本书的内容===========
SAX解析结束
~!~!~!共有2本书
1
冰与火之歌
乔治马丁
2014
89
null
----finish----
2
安徒生童话
null
2004
77
English
----finish----

原文地址:https://www.cnblogs.com/churujianghudezai/p/11405408.html

时间: 2024-10-28 11:23:53

Java中XML的四种解析方式(二)的相关文章

XML解析——Java中XML的四种解析方式

 XML是一种通用的数据交换格式,它的平台无关性.语言无关性.系统无关性.给数据集成与交互带来了极大的方便.XML在不同的语言环境中解析方式都是一样的,只不过实现的语法不同而已. XML的解析方式分为四种:1.DOM解析:2.SAX解析:3.JDOM解析:4.DOM4J解析.其中前两种属于基础方法,是官方提供的平台无关的解析方式:后两种属于扩展方法,它们是在基础的方法上扩展出来的,只适用于java平台. 针对以下XML文件,会对四种方式进行详细描述: 1 <?xml version="1.

黑马程序员——XML解析---java中XML的四种解析方式

------Java培训.Android培训.iOS培训..Net培训.期待与您交流! ------- XML是一种通用的数据交换格式,它的平台无关性.语言无关性.系统无关性.给数据集成与交互带来了极大的方便.XML在不同的语言环境中解析方式都是一样的,只不过实现的语法不同而已. XML的解析方式分为四种:1.DOM解析:2.SAX解析:3.JDOM解析:4.DOM4J解析.其中前两种属于基础方法,是官方提供的平台无关的解析方式:后两种属于扩展方法,它们是在基础的方法上扩展出来的,只适用于jav

XML的四种解析方式

基础方法: DOM.SAX DOM:与平台无关的官方解析方式 SAX:基于事件驱动的解析方式 扩展方法:JDOM.DOM4J(在基础的方法上扩展的,只有Java能够使用的解析方式) DOM: 一次性解析完毕! import java.io.FileOutputStream; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.tran

Xml的三种解析方式

XML的三种解析方式:DOM.SAX.PULL解析 废话不说上代码: package com.minimax.xmlparsedemo; import java.io.InputStream; import java.util.List; import android.os.Bundle; import android.app.Activity; import android.content.res.AssetManager; import android.util.Log; import an

XML的四种解析器原理及性能比较

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

【学习笔记】——原生js中常用的四种循环方式

一.引言 本文主要是利用一个例子,讲一下原生js中常用的四种循环方式的使用与区别: 实现效果: 在网页中弹出框输入0   网页输出"欢迎下次光临" 在网页中弹出框输入1   网页输出"查询中--" 在网页中弹出框输入2   网页输出"取款中--" 在网页中弹出框输入3   网页输出"转账进行中--" 在网页中弹出框输入其他字符   网页输出"无效按键" 四种循环: for循环 while循环 for  in

xml的两种解析方式

xml解析是日常项目中用到比較多的技能.不管是配置參数或者数据都能够保存在xml文件里.同一时候也能够将xml作为数据传输的一种格式.本文将介绍两种基本解析方式:xml字符串解析和xml文件解析. xml字符串解析 package com.discover.parse; import java.util.Iterator; import org.dom4j.Document; import org.dom4j.DocumentException; import org.dom4j.Documen

Android中Activity的四种启动方式

谈到Activity的启动方式必须要说的是数据结构中的栈.栈是一种只能从一端进入存储数据的线性表,它以先进后出的原则存储数据,先进入的数据压入栈底,后进入的数据在栈顶.需要读取数据的时候就需要从顶部开始读取数据,栈具有记忆功能,对栈的操作不需要指针的约束.在Android中Activity的显示其实就是一个入栈和出栈的过程.当打开一个Activity的时候Activity入栈,当关闭一个Activity的时候Activity出栈,用户操作的Activity位于栈顶,一般情况下,一个应用程序对应一

JAVA中单例模式的几种实现方式

1 线程不安全的实现方法 首先介绍java中最基本的单例模式实现方式,我们可以在一些初级的java书中看到.这种实现方法不是线程安全的,所以在项目实践中如果涉及到线 程安全就不会使用这种方式.但是如果不需要保证线程安全,则这种方式还是不错的,因为所需要的开销比较小.下面是具体的实现代码: 转http://www.cnblogs.com/CodeGuy/p/3580486.html public Class Singleton { private static Singleton instance