首先要下载JDOM.jar包,下载地址:http://download.csdn.net/detail/ww6055/8880371

下载到JDOM.jar包之后导入到工程中去。

实例程序:

books.xml文件:(注:books.xml文件在src/res文件夹下)

Book.java实体类:

public class Book {
    private String id;
    private String name;
    private String price;
    private String author;
    private String year;
    private String language;
    public String getLanguage() {
        return language;
    }
    public void setLanguage(String language) {
        this.language = language;
    }
    public String getId() {
        return id;
    }
    public void setId(String id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public String getPrice() {
        return price;
    }
    public void setPrice(String price) {
        this.price = price;
    }
    public String getAuthor() {
        return author;
    }
    public void setAuthor(String author) {
        this.author = author;
    }
    public String getYear() {
        return year;
    }
    public void setYear(String year) {
        this.year = year;
    }
}

SAXTest.java类实现对books.xml文件的解析(注:文件中需要导入的AttributeDocumentElementJDOMException都是JDOM包下的):

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.List;
import java.util.Vector;
import org.jdom.Attribute;
import org.jdom.Document;
import org.jdom.Element;
import org.jdom.JDOMException;
import org.jdom.input.SAXBuilder;
import com.xml.Jdom.model.Book;

public class JdomTest {

 //对books.xml文件进行JDOM解析
    public static void main(String[] args) {
        List<Book> booklist = new ArrayList<Book>();
        //STEP1.创建一个SAXBuilder对象
        SAXBuilder sBuilder = new SAXBuilder();
        InputStream in;
        try {
            //STEP2.创建一个输入流,将xml文件加载到输入流中
            in= new FileInputStream("src/res/books.xml");
            //进一步包装成InputStreamReader对象,处理乱码现象
            InputStreamReader isr = new InputStreamReader(in,"utf-8");
            //STEP3.通过SAXBuilder对象的build方法,将输入流加载到saxBuilder中
            Document doc=sBuilder.build(isr);
            //STEP4.通过Document对象可以获取bookstore的根节点
            Element ele = doc.getRootElement();
            //STEP5.获取根节点下的子节点的集合
            List<Element> bookList = ele.getChildren();
            //继续解析
            for(Element book:bookList){
                System.out.println("============开始解析第"+(bookList.indexOf(book)+1)+"本书===============");
                Book b = new Book();
                //如果一直输姓名则可以直接获取属性值:System.out.println(book.getAttributeValue("id"));
                //book下所有的属性
                List<Attribute> attrList=book.getAttributes();
                for(Attribute attr:attrList){
                    System.out.println("属性名是:"+attr.getName()+" ***** 属性值是:"+attr.getValue());
                    if(attr.getName().equals("id"))
                        b.setId(attr.getValue());
                }
                List<Element> list = book.getChildren();
                for(Element element:list){
                    System.out.println("节点名:"+element.getName()+" *******  节点值:"+element.getValue());
                    if(element.getName().equals("name"))
                        b.setName(element.getValue());
                    if(element.getName().equals("author"))
                        b.setAuthor(element.getValue());
                    if(element.getName().equals("year"))
                        b.setYear(element.getValue());
                    if(element.getName().equals("price"))
                        b.setPrice(element.getValue());
                    if(element.getName().equals("language"))
                        b.setLanguage(element.getValue());
                }
                booklist.add(b);
                b=null;//把Book对象设置为空,防止出现属性设置现象
            //    System.out.println(book.getAttributes());
            //    System.out.println("节点值是:"+book.getValue());
                System.out.println("============结束解析第"+(bookList.indexOf(book)+1)+"本书===============");
                
            }
            System.out.println(booklist.get(0).getName()+"****"+booklist.get(1).getName());
        } catch (FileNotFoundException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }catch (JDOMException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }
}

JDOM方法实现对XML文件的解析的更多相关文章

  1. 【JAVA使用XPath、DOM4J解析XML文件,实现对XML文件的CRUD操作】

    一.简介 1.使用XPath可以快速精确定位指定的节点,以实现对XML文件的CRUD操作. 2.去网上下载一个“XPath帮助文档”,以便于查看语法等详细信息,最好是那种有很多实例的那种. 3.学习X ...

  2. linux下使用libxml2实现对xml文件的读取及查询

    由于项目需要,这两天在用C++做XML文件解析的工作.在linux下有个很方便的操作xml文件的库——libxml2,它提供了一套创建和查询xml文件的C语言的接口.这篇博客主要介绍如何使用libxm ...

  3. 用DOM4J包实现对xml文件按属性分离。

    转自本人博客:http://www.xgezhang.com/dom4j_xml_separata.html dom4j是一个Java的XML API.类似于jdom.用来读写XML文件的. dom4 ...

  4. asp.net 实现对xml文件的 读取,添加,删除,修改

    用于修改站内xml文件 已知有一个XML文件(bookstore.xml)如下:<?xml version="1.0" encoding="gb2312" ...

  5. 使用jq的ajax实现对xml文件的读取

    之前一直在用json来传递数据,但是xml也是不可缺少的,于是开始了xml的征程.xml的一些属性啊之类的在菜鸟教程上列举的已经很详细了,但是却没有前段部分的获取教程,查询资料,遂懂: index.x ...

  6. Android平台中实现对XML的三种解析方式

    本文介绍在Android平台中实现对XML的三种解析方式. XML在各种开发中都广泛应用,Android也不例外.作为承载数据的一个重要角色,如何读写XML成为Android开发中一项重要的技能. 在 ...

  7. 【文件处理】xml 文件 SAX解析

    SAX的全称是Simple APIs for XML,也即XML简单应用程序接口. 与DOM不同,SAX提供的访问模式是一种顺序模式,这是一种快速读写XML数据的方式. 当使用SAX分析器对XML文档 ...

  8. 【文件处理】xml 文件 DOM解析

    一.Java解析xml.解析xml四种方法.DOM.SAX.JDOM.DOM4j.XPath 此文针对其中的DOM方法具体展开介绍及代码分析 sax.dom是两种对xml文档进行解析的方法(没有具体实 ...

  9. [置顶] Android开发之XML文件的解析

    Android系统开发之XML文件的解析 我们知道Http在网络传输中的数据组织方式有三种分别为:XML方式.HTML方式.JSON方式.其中XML为可扩展标记语言,如下: <?xml vers ...

随机推荐

  1. [css]inline-block

    能被父容器居中.能设置高度宽度和margin.不会像table或div那样占一正行……——这就是inline-block——记得这是浏览器默认样式告诉你的.

  2. rank() | dense_rank() | row_number() over(PARTITION BY sex order by age desc ) 的区别

    1.row_num() over()函数:根据某个字段排序后编号1,2,3.. select *,ROW_NUMBER() over ( order by majorid) as numfrom St ...

  3. Packetbeat协议扩展开发教程(3)

    原文链接:http://elasticsearch.cn/article/54 书接上回:http://elasticsearch.cn/article/53 前面介绍了Packetbeat的项目结构 ...

  4. 清空session的方法

    清空session的方法,常用来注销的时候清空所有的session. 方法一: Enumeration e=session.getAttributeNames(); while(e.hasMoreEl ...

  5. 【M13】以by reference 方式捕捉exceptions

    1.catch语句的参数有三种方式:by pointer,by value,by reference. 2.首先考虑,by pointer.这意味着抛出端必须抛出一个对象的地址.那么问题来了: 如果这 ...

  6. Codeforces Round #321 (Div. 2) E. Kefa and Watch 线段树hash

    E. Kefa and Watch Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/580/prob ...

  7. BZOJ 1151 傲娇的人 排序

    傲娇的人 Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://acm.uestc.edu.cn/#/problem/show/1151 Descrip ...

  8. c++ 操作注冊表

    1.       注冊表简单介绍 注冊表是为Windows NT和Windows95中全部32位硬件/驱动和32位应用程序设计的数据文件,用于存储系统和应用程序的设置信息.16位驱动在Winnt (W ...

  9. shell重定向调试信息

    shell重定向调试信息 fulinux ******************************************************************************* ...

  10. string中find函数的使用

    9.47 编写程序,首先查找string"ab2c3d7R4E6"中的每个数字字符,然后查找其中每个字母字符.编写两个版本的程序,第一个要使用find_first_of,第二个要使 ...