`
guyinglong
  • 浏览: 73944 次
  • 性别: Icon_minigender_1
  • 来自: 江西
社区版块
存档分类
最新评论

xml说明

    博客分类:
  • xml
阅读更多
在java环境下读取xml文件的方法主要有4种:DOM、SAX、JDOM、JAXB
1.  DOM(Document Object Model)
此方法主要由W3C提供,它将xml文件全部读入内存中,然后将各个元素组成一棵数据树,以便快速的访问各个节点 。 因此非常消耗系统性能 ,对比较大的文档不适宜采用DOM方法来解析。 DOM API 直接沿袭了 XML 规范。每个结点都可以扩展的基于 Node 的接口,就多态性的观点来讲,它是优秀的,但是在 Java 语言中的应用不方便,并且可读性不强。
实例:
import javax.xml.parsers.*;
//XML解析器接口
import org.w3c.dom.*;
//XML的DOM实现
import org.apache.crimson.tree.XmlDocument;
//写XML文件要用到

DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
//允许名字空间
factory.setNamespaceAware(true);
//允许验证
factory.setValidating(true);
//获得DocumentBuilder的一个实例
try {
DocumentBuilder builder = factory.newDocumentBuilder();
} catch (ParserConfigurationException pce) {
System.err.println(pce);
//  出异常时输出异常信息,然后退出,下同
System.exit(1);
}
//解析文档,并获得一个Document实例。
try {
Document doc = builder.parse(fileURI);
} catch (DOMException dom) {
System.err.println(dom.getMessage());
System.exit(1);
} catch (IOException ioe) {
System.err.println(ioe);
System.exit(1);    
}

//获得根节点StuInfo
Element elmtStuInfo = doc.getDocumentElement();

//得到所有student节点
NodeList nlStudent = elmtStuInfo.getElementsByTagNameNS(
                                       strNamespace, "student");
for (……){
     //当前student节点元素
     Element elmtStudent = (Element)nlStudent.item(i);

     NodeList nlCurrent =              elmtStudent.getElementsByTagNameNS(
                                     strNamespace, "name");
}


对于读取得方法其实是很简单的,写入xml文件也是一样不复杂。

DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = null;
try {
builder = factory .newDocumentBuilder();
} catch (ParserConfigurationException pce) {
System.err.println(pce);
System.exit(1);
}

Document doc = null;
doc = builder .newDocument();

//下面是建立XML文档内容的过程,
//先建立根元素"学生花名册"
Element root = doc.createElement("学生花名册");
//根元素添加上文档
doc.appendChild(root);
//建立"学生"元素,添加到根元素
Element student = doc.createElement("学生");
student.setAttribute("性别", studentBean.getSex());
root.appendChild(student);
//建立"姓名"元素,添加到学生下面,下同
Element name = doc.createElement("姓名");
student.appendChild(name);
Text tName = doc.createTextNode(studentBean.getName());
name.appendChild(tName);

Element age = doc.createElement("年龄");
student.appendChild(age);
Text tAge = doc.createTextNode(String.valueOf(studentBean.getAge()));
age.appendChild(tAge);

2.SAX (Simple API for XML)
此方法主要由XML-DEV 邮件列表的成员开发的,SAX是基于事件的方法,它很类似于标签库的处理机制,在标签开始、结束以及错误发生等等地方调用相应的接口实现方法,不是全部文档都读入内存。 SAX具有优异的性能和利用更少的存储空间特点。SAX 的设计只考虑了功能的强大性,却没有考虑程序员使用起来是否方便。

使用必须扩展ContentHandler、ErrorHandler、DTDHandler等,但是必须扩展ContentHandler(或者DefaultHandler )。

import org.xml.sax.*;

public  class  MyContentHandler implements ContentHandler {
  … …
}

/**
     * 当其他某一个调用事件发生时,先调用此方法来在文档中定位。
     * @param locator
     */
    public void setDocumentLocator(Locator locator){

    }
/**
     * 在解析整个文档开始时调用
     * @throws SAXException
     */
    public void startDocument() throws SAXException{
        System.out.println("** Student information start **");
    }
/**
     * 在解析整个文档结束时调用
     * @throws SAXException
     */
    public void endDocument() throws SAXException{
        System.out.println("**** Student information end ****");
    }

/**
     * 在解析名字空间开始时调用
     * @param prefix
     * @param uri
     * @throws SAXException
     */
    public void startPrefixMapping(String prefix
        , String uri) throws SAXException{
    }
/**
     * 在解析名字空间结束时调用
     * @param prefix
     * @throws SAXException
     */
    public void endPrefixMapping(String prefix) throws SAXException{
    }
/**
     * 在解析元素开始时调用
     * @param namespaceURI
     * @param localName
     * @param qName
     * @param atts
     * @throws SAXException
     */
    public void startElement(String namespaceURI, String localName
        , String qName, Attributes atts) throws SAXException{
    }
/** 在解析元素结束时调用
     * @param namespaceURI
     * @param localName 本地名,如student
     * @param qName 原始名,如LIT:student
     * @throws SAXException   */
    public void endElement(String namespaceURI, String localName,String qName) throws SAXException{
  if (localName.equals(“student”)){
            System.out.println(localName+":"+currentData);
        }
}
取得元素数据的方法——characters
取得元素数据中的空白的方法——ignorableWhitespace
在解析到处理指令时调用的方法——processingInstruction
当未验证解析器忽略实体时调用的方法——skippedEntity
运行时,只需要使用下列代码:

MySAXParser mySAXParser = new MySAXParser();

mySAXParser.parserXMLFile("SutInfo.xml");


3.JDOM

JDOM的处理方式有些类似于DOM,但它主要是用SAX实现的 。JDOM用Java的数据类型来定义操作数据树的各个节点 。JDOM的性能也很优越。


import org.jdom.*;
import org.jdom.input.*;
import org.jdom.output.*;

SAXBuilder builder = new SAXBuilder(false);
//得到Document
Document doc = builder.build(fileURI);
//名字空间
Namespace ns = Namespace.getNamespace("LIT"
                           , "http://www.lit.edu.cn/student/");

//取得所有LIT:student节点的集合
List lstStudents = elmtStuInfo.getChildren("student",                                                                                                   ns);

for ( … ){
Element elmtStudent = (Element)lstStudents.get(i);
elmtStudent.getChildTextTrim("name", ns);
}
//修改
elmtLesson.getChild("lessonScore" , ns).setText("100");
//删除
elmtStuInfo.removeChild("master", ns);
//添加
elmtStuInfo.addContent(new Element("master" , ns).addContent(new Entity("masterName")));
//输出文档
//第一个参数是缩进字符串,这里是4个空格。
//第二个参数是true,表示需要换行。
XMLOutputter printDoc = new XMLOutputter(" ", true);
printDoc.output(doc, new FileOutputStream("StuInfo.xml"));

4.JAXB (Java And XML Binding)

JAXB 是以SUN为主的一些公司公布的。JAXB将schema(或者DTD)映射为java对象(.java文件),然后使用这些java对象来解析xml文件。需要使用之前生成java文件,因而要有固定的schema,无法处理动态的xml文件。

首先使用xjc命令,生成java文件
  xjc  [-options ...]

(生成的文件较多)
JAXBContext jc = JAXBContext.newInstance(“packageName");

Unmarshaller unmarshaller = jc.createUnmarshaller();

Collection collection= (Collection)unmarshaller.unmarshal(new File( "books.xml"));
CollectionType.BooksType booksType =collection.getBooks();
List bookList = booksType.getBook();
for( … ){
test.jaxb.BookType book =(test.jaxb.BookType) bookList.get(i);
System.out.println("Book Name: " + book.getName().trim());
   System.out.println("Book ISBN: " +  book.getISBN());
}

分享到:
评论

相关推荐

    solrconfig.xml和schema.xml说明

    ### Solrconfig.xml 和 Schema.xml 说明 #### Solrconfig.xml 概述 Solrconfig.xml 是 Apache Solr 的核心配置文件之一,主要用于定义 Solr 实例如何处理文档的索引与查询请求。该文件中包含了多种配置项,用于...

    spring application-context xml说明

    spring application-context xml说明

    金税盘导入模板XML,XML 格式 说明

    金税盘导入模板XML,XML 格式 说明

    xml说明(精简版)

    xml说明的待定待定待定地对地导弹福福福福福福福福福福发发发

    Tomcat配置文件server.xml说明.doc

    Tomcat配置文件server.xml说明.doc

    jdom读写xml说明

    XML(eXtensible Markup Language)是一种用于存储和传输数据的标记语言,广泛应用于Web服务、配置文件和数据交换等领域。JDOM是Java中处理XML的一种库,它提供了一种高效且易于使用的API来创建、读取和修改XML文档...

    用友NC凭证导入XML中文说明

    用友NC凭证导入XML中文说明 <?xml version="1.0" encoding='UTF-8'?> <voucher_head>

    weblogic.xml说明

    详细介绍weblogic.xml的元素

    tinyxml说明文档

    ### TinyXML概述与基本使用 #### 一、TinyXML简介 TinyXML是一个轻量级的C++ XML解析库,它的设计简洁且易于使用,适用于快速开发。TinyXML由Grinning Lizard Software提供,并且可以在其官网上找到详细的文档和...

    berkeley db xml说明手册

    《Berkeley DB XML详解》 Berkeley DB XML是一款强大的数据存储和管理工具,结合了数据库管理系统(DBMS)的功能和XML的数据表示能力。这款产品由Oracle公司开发,旨在为应用程序提供高效、灵活的XML数据存储解决...

    TongWeb主配置文件tongweb.xml概要说明

    《TongWeb主配置文件tongweb.xml详解》 TongWeb是一款基于Java技术的高性能、高可用的企业级应用服务器,其核心配置文件——tongweb.xml,是TongWeb运行时的重要配置中心,用于定义服务器的行为、管理应用程序的...

    APICloud-config.xml说明

    在APICloud的开发过程中,`APICloud-config.xml`配置文件起着至关重要的作用。这个文件是APICloud项目的配置中心,用于设置应用的基本信息、权限控制以及各种模块的个性化配置。 1. **基本信息配置** `APICloud-...

    maven的pom.xml说明详解

    -打包文件前置.xml- -全局属性配置- -NJCC开发环境(MySQL)- -部署环境(对应配置文件版本)- -设置默认环境- -NJCC开发环境(Oracle)- -部署环境(对应配置文件版本)- -配置maven地址- -外网- -版本增加- -表示test...

    TinyXML说明

    TinyXML是一个小型、易于集成的C++ XML解析器库,它能够解析XML文档并构建出一个可读、可修改、可保存的文档对象模型(Document Object Model,DOM)。XML,全称“可扩展标记语言”,是一种允许用户创建自己文档标记...

    java配置web.xml说明

    WEB-INF中web.xml设置的详细说明,很全的

    PLCOpen XML 格式说明

    综上所述,PLCOpen XML格式说明是自动化领域中为了实现PLC编程的标准化、结构化以及平台无关性所作出的重要努力。它不仅可以提高软件的可移植性,还可以帮助不同厂商生产的PLC设备之间实现更高效的互操作性。通过...

    TinyXml源码和使用说明

    TinyXml是一款轻量级的XML解析库,专为嵌入式系统和小型应用设计,它提供了C++接口来读写XML文档。TinyXml的核心优势在于其...通过深入理解TinyXml的源码和使用说明,开发者可以更高效地利用这个工具来满足项目需求。

    倍福设备说明Beckhoff_EtherCAT_XML.zip

    标题 "Beckhoff_EtherCAT_XML.zip" 涉及的是倍福(Beckhoff)公司的EtherCAT(Ethernet for Control Automation Technology)技术相关的设备说明。 EtherCAT 是一种高性能的工业以太网通信协议,用于实时控制自动化...

    XML与XMLSchema

    --...-->`表示,用于提供文档的人类可读说明。 5. **处理指令**:`<?...?>`,通常用于向处理器发送指令,如PHP的`<?php ... ?>`。 6. **实体**:预定义或自定义的字符或字符串,例如`<!ENTITY dw "developerWorks">`...

    XMLDB说明DATASHEET

    ### XMLDB说明DATASHEET #### 概述与新特性 **Oracle XML DB** 是一个在 **Oracle Database 10g Release 2** 中引入的功能模块,它为数据库增加了高性能的原生XML存储和检索能力。通过 **Oracle XML DB Repository...

Global site tag (gtag.js) - Google Analytics