一、前言

Jdom是什么?

Jdom是一个开源项目,基于树形结构,利用纯java的技术对XML文档实现解析,生成,序列化以及多种操作。它是直接为java编程服务,利用java语言的特性(方法重载,集合),把SAX和DOM的功能结合起来,尽可能的把原来解析xml变得简单,我们使用Jdom解析xml会是一件轻松的事情。

Jdom的优点:

1、Jdom专用于java技术,比Dom应用占用更少内存。

2、Jdom提供更加简单和逻辑性访问xml信息的基础方法

3、除xml文件外,Jdom还可以访问其他的数据源,例如可以创建类从SQL查询结果中访问数据

Jdom的构成:

Jdom由6个包构成

Element类表示XML文档的元素

org.jdom:      解析xml文件所要用到的基础类

org.jdom.adapters:   包含DOM适配的Java类

org.jdom.filter:      包含xml文档的过滤类

org.jdom.input:     包含读取XML文档的Java类

org.jdom.output:      包含输出XML文档的类

org.jdom.trans form: 包含将Jdom xml文档接口转换为其他XML文档接口的Java类

xml是什么?

xml是一种广为使用的可扩展标记语言,java中解析xml的方式有很多,最常用的像jdom、dom4j、sax等等。

Jdom包下载:http://www.jdom.org/downloads/index.html

这里笔者代码做的是使用java创建一个xml和读取一个xml,仅作为笔记介绍。

二、操作

下载jdom包,解压文件jdom-2.0.6.jar,jdom-2.0.6-javadoc.jar,将包导入到lib文件夹下。(注,如果有错误的话,将Jdom中的包全部导入)

例子1:使用jdom创建一个xml文件,名字为people.xml

新建类CareateJdom

package com.book.jdom;

import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException; import org.jdom2.Document;
import org.jdom2.Element;
import org.jdom2.output.Format;
import org.jdom2.output.XMLOutputter; //生成xml文件
public class CreateJdom { public static void main(String[] args) {
//定义元素
Element people,student;
people = new Element("people");
student = new Element("student");
//设置属性
student.setAttribute("name", "张三");
student.setAttribute("salary","8000");
//设置文本
student.setText("呵呵");
//将其添加到根目录下
people.addContent(student); //新建一个文档。
Document doc = new Document(people);
//读取格式,赋值给当前的Format
Format format = Format.getCompactFormat();
//对当前格式进行初始化
format.setEncoding("UTF-8");
//设置xml文件缩进4个空格
format.setIndent(" ");
//建一个xml输出工厂,将格式给工厂
XMLOutputter xmlout = new XMLOutputter(format);
try {
//将其写好的文本给工厂,并且建一个文件输出流,将数据输出
xmlout.output(doc, new FileOutputStream("people.xml"));
System.out.println("成功!");
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
} /*运行结果:
<?xml version="1.0" encoding="UTF-8"?>
<people>
<student name="张三" salary="8000" />
</people>
* */

例子2:使用Jdom解析people.xml文件

新建Readxml类

package com.book.jdom;

import java.io.IOException;
import java.util.List; import org.jdom2.Document;
import org.jdom2.Element;
import org.jdom2.JDOMException;
import org.jdom2.input.SAXBuilder; //读取people.xml文档
public class Readxml { public static void main(String[] args) {
//新建构造器解析xml
SAXBuilder sax = new SAXBuilder();
//建一个文档去接受数据
Document doc;
try {
//获取people.xml文档
doc = sax.build("people.xml");
//获得根节点
Element people = doc.getRootElement();
//获得根节点下的节点数据
List<Element> list = people.getChildren();
for(int i = 0;i<list.size();i++){
Element e = list.get(i);
//获得属性值
System.out.println("name:"+e.getAttributeValue("name")+" salary:"+e.getAttributeValue("salary"));
//获得文本值
System.out.println(e.getText());
}
} catch (JDOMException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
}
/*
* 运行结果:
* name:张三 salary:8000
呵呵
* */

解析xml

用jdom获取多个相同标签名的不同属性值的方法
<?xml version="1.0" encoding="UTF-8"?>
<Configuration>
<Key Name="China">
<Value Name="TextKey">China</Value>
<Value Name="Enabled">true</Value>
<Value Name="PhotoIDWidth">38PhotoIDWidth</Value>
<Value Name="PhotoIDHeight">38</Value>
<Key Name="Adult">
<Value Name="CrownPercent">0.10</Value>
<Value Name="HeadPercent">0.60AdultHeadPercent</Value>
</Key>
<Key Name="Child">
<Value Name="CrownPercent">0.10</Value>
<Value Name="HeadPercent">0.60ChildHeadPercent</Value>
</Key>
</Key>
<Key Name="Australia">
<Value Name="TextKey">Australia</Value>
<Value Name="Enabled">true</Value>
<Value Name="PhotoIDWidth">35PhotoIDWidth</Value>
<Value Name="PhotoIDHeight">45</Value>
<Key Name="Adult">
<Value Name="CrownPercent">0.061</Value>
<Value Name="HeadPercent">0.756"Adult"HeadPercent</Value>
</Key>
<Key Name="Child">
<Value Name="CrownPercent">0.072</Value>
<Value Name="HeadPercent">0.711ChildHeadPercent</Value>
</Key>
</Key>
<Key Name="Austria">
<Value Name="TextKey">Austria</Value>
<Value Name="Enabled">true</Value>
<Value Name="PhotoIDWidth">35PhotoIDWidth</Value>
<Value Name="PhotoIDHeight">45</Value>
<Key Name="Adult">
<Value Name="CrownPercent">0.064</Value>
<Value Name="HeadPercent">0.744AdultHeadPercent</Value>
</Key>
<Key Name="Child">
<Value Name="CrownPercent">0.078</Value>
<Value Name="HeadPercent">0.689ChildHeadPercent</Value>
</Key>
</Key>
</Configuration> package input; import java.io.IOException;
import java.util.ArrayList;
import java.util.List; import org.jdom.Document;
import org.jdom.Element;
import org.jdom.JDOMException;
import org.jdom.input.SAXBuilder; public class ReadXML { /**
* @param args
*/
public static void main(String[] args) throws JDOMException, IOException {
SAXBuilder sb = new SAXBuilder();
//构造文档对象
Document doc = sb.build(Test.class.getClassLoader().getResourceAsStream("nation.xml"));
//获取根元素
Element root = doc.getRootElement();
//定位到<Configuration> -> <Key>
List<Element> list = root.getChildren("Key");
List<Element> children = new ArrayList<Element>();
List<Element> childrens = new ArrayList<Element>();
for (int i = 0; i < list.size(); i++) {
Element element = (Element) list.get(i);
System.out.print(element.getAttributeValue("Name"));
//定位到<Configuration> -> <Key> -> <Value>
children = element.getChildren("Value");
for(int j=0; j<children.size(); j++){
Element elementChildren = (Element) children.get(j);
//定位到<Configuration> -> <Key> -> <Value Name="PhotoIDWidth">
if(elementChildren.getAttributeValue("Name").equals("PhotoIDWidth")){
//获取<Configuration> -> <Key> -> <Value Name="PhotoIDWidth"> 属性值
System.out.print("<--------->"+elementChildren.getAttributeValue("Name"));
//获取<Configuration> -> <Key> -> <Value Name="PhotoIDWidth"> 标签里内容
System.out.print(","+elementChildren.getText());
}
}
children.clear();
//定位到<Configuration> -> <Key> -> <Key>
children = element.getChildren("Key");
for(int j=0; j<children.size(); j++){
Element elementChildren = (Element)children.get(j);
//定位到<Configuration> -> <Key> -> <Key Name="Child">
if(elementChildren.getAttributeValue("Name").equals("Child")){
//定位到<Configuration> -> <Key> -> <Key Name="Child"> -> <Value>
childrens = elementChildren.getChildren("Value");
for(int k=0; k<childrens.size(); k++){
Element elementChildrens = (Element)childrens.get(k);
//定位到<Configuration> -> <Key> -> <Key Name="Child"> -> <Value Name="HeadPercent">
if(elementChildrens.getAttributeValue("Name").equals("HeadPercent")){
System.out.println("<--------->"+elementChildrens.getText());
}
}
}
}
}
}
} 打印结果:
China<--------->PhotoIDWidth,38PhotoIDWidth<--------->0.60ChildHeadPercent
Australia<--------->PhotoIDWidth,35PhotoIDWidth<--------->0.711ChildHeadPercent
Austria<--------->PhotoIDWidth,35PhotoIDWidth<--------->0.689ChildHeadPercent Jdom解析xml代码

Jdom解析xml

Javaweb学习笔记——使用Jdom解析xml的更多相关文章

  1. Javaweb学习笔记——(六)——————xml中jaxp两种解析方式和dom4j运用

    1.xml的scheam约束 dtd的语法:<!ElEMENT 元素名称 约束> **schema符合xml的语法,xml语句 **一个xml中可以有多个schema,多个schema使用 ...

  2. 【Android学习笔记】XmlResourceParser解析xml文件

    最近学习Android时,需要用到解析XML文件里的数据,可以用XmlResourceParser来解析xml文件,正好将此记录下来. XmlResourceParser里常用的字段和方法 首先先给出 ...

  3. javaEE学习笔记-利用DOM4J解析xml至数据库

    xml代码文件名:test02.xml <ACCESOS> <item> <SOCIO> <NUMERO>00045050</NUMERO> ...

  4. JavaWeb学习笔记总结 目录篇

    JavaWeb学习笔记一: XML解析 JavaWeb学习笔记二 Http协议和Tomcat服务器 JavaWeb学习笔记三 Servlet JavaWeb学习笔记四 request&resp ...

  5. jdom解析xml

    这次把代码整理了一下,打包发上来了,程序中需要用到的jar包也一起打在里面了,有兴趣的朋友可以解压后直接导入的eclipse里运行! xml是一种广为使用的可扩展标记语言,java中解析xml的方式有 ...

  6. javaweb学习笔记整理补课

    javaweb学习笔记整理补课 * JavaWeb: * 使用Java语言开发基于互联网的项目 * 软件架构: 1. C/S: Client/Server 客户端/服务器端 * 在用户本地有一个客户端 ...

  7. [置顶] Android学习系列-Android中解析xml(7)

    Android学习系列-Android中解析xml(7) 一,概述 1,一个是DOM,它是生成一个树,有了树以后你搜索.查找都可以做. 2,另一种是基于流的,就是解析器从头到尾解析一遍xml文件.   ...

  8. 简单使用JDOM解析XML

    原文:http://liuwentao.iteye.com/blog/59978 使用JDOM解析XML一.前言JDOM是Breet Mclaughlin和Jason Hunter两大Java高手的创 ...

  9. Java jdom解析xml文件带冒号的属性

    Java jdom解析xml文件带冒号的属性 转载请标明出处: https://dujinyang.blog.csdn.net/article/details/99644824 本文出自:[奥特曼超人 ...

随机推荐

  1. T型及Fly_by拓扑之应用总结

    前面的文章有分别介绍过T型拓扑及Fly_by拓扑结构,这两种拓扑结构应用最多的应该是在DDR3里面,说到这里,小编又想开始聊聊DDR3的设计了,我想很多人都比较有兴趣. 因为DDR3的设计还是比较复杂 ...

  2. Chrome开发者工具不完全指南(四、性能进阶篇)

    前言 Profiles面板功能的作用主要是监控网页中各种方法执行时间和内存的变化,简单来说它就是Timeline的数字化版本.它的功能选项卡不是很多(只有三个),操作起来比较前面的几块功能版本来说简单 ...

  3. 工作任务:模拟淘宝登录和购物车功能:使用cookie记录登录名,下次登录时能够记得上次的登录名,使用cookie模拟购物车功能,使用session记住登录信息并验证是否登录,防止利用url打开网站,并实现退出登录功能

    登入界面<% Cookie[] cks =request.getCookies(); String str=null; for(Cookie ck:cks) { if(ck.getName(). ...

  4. SQL Server 解读【已分区索引的特殊指导原则】(1)- 索引对齐

    一.前言 在MSDN上看到一篇关于SQL Server 表分区的文档:已分区索引的特殊指导原则,如果你对表分区没有实战经验的话是比较难理解文档里面描述的意思.这里我就里面的一些概念进行讲解,方便大家的 ...

  5. 《JS设计模式笔记》 3,观察者模式

    <script type="text/javascript"> //挂插着模式又叫发布订阅模式应该是最常用的模式 //1,dom事件就是观察者模式,只要订阅了click ...

  6. ASP.NET Core的配置(2):配置模型详解

    在上面一章我们以实例演示的方式介绍了几种读取配置的几种方式,其中涉及到三个重要的对象,它们分别是承载结构化配置信息的Configuration,提供原始配置源数据的ConfigurationProvi ...

  7. 克隆您的Git代码库和添加源文件

    内容正在建设中 标签:Bitbucket

  8. BFC之浅析篇

    BFC是什么呢? 掏粪男孩? 当然不是咯.BFC,英文名Block formatting context,直译为“块级格式化上下文”.它是W3C CSS 2.1规范中的一个概念,决定了元素如何对内容进 ...

  9. MySQL学习笔记一:常用显示命令

    1.开启和关闭MySQL服务 WIN平台:NET START MYSQL55 :NET STOP MYSQL55 Linux平台:service mysql start : service mysql ...

  10. EntityFramework 7 Linq Contains In 奇怪问题(已修复)

    问题说明: 博客问题纪录 Use EF7, Linq Contains In is error. EF7 Code Commit adding (client side) support for Co ...