java环境下读取xml文件的方法

原创 2011年01月11日 08:35:00

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

import javax.xml.parsers.*; 
//XML解析器接口 
import org.w3c.dom.*; 
//XMLDOM实现 
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 的设计只考虑了功能的强大性,却没有考虑程序员使用起来是否方便。
使用必须扩展ContentHandlerErrorHandlerDTDHandler等,但是必须扩展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实现的 JDOMJava的数据类型来定义操作数据树的各个节点 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为主的一些公司公布的。JAXBschema(或者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());
}

 

android Studio 解析assets下xml文件并解析

android Studio 解析assets下xml文件并解析: language.xml Language cat="it">       lan id="1">       ...
  • bysjlwdx
  • bysjlwdx
  • 2017年11月02日 13:41
  • 264

Android开发中获取assets文件夹下Xml文件的问题

这是我的一个测试类中的部分代码。我在assets文件夹下放了一个xml文件,名称:whitelist.xml parentcontext就是传入的主activity。 InputStr...
  • brandon2015
  • brandon2015
  • 2015年12月09日 22:56
  • 449

android从assets文件夹中读取xml文件

Context.getAssets().openXmlResourceParser(fileNameString) 出现FileNotFoundException,认为assets文件夹的文件须用op...
  • brandon2015
  • brandon2015
  • 2015年12月09日 22:23
  • 2660

XmlReader怎么读取指定节点的内容??(问-答)

 C# code XmlDocument doc = new XmlDocument(); doc.Load("xxx.xml"); XmlNodeList nodeLis...
  • QQ1449301756
  • QQ1449301756
  • 2014年08月14日 23:10
  • 558

boost读取xml文件

boost的property_tree可以用来读取xml文件。用到的类 boost::property_tree::ptree,这个是用来保存解析后的xml数据流的类,解析函数read_xml,这个函...
  • linfengmove
  • linfengmove
  • 2014年12月13日 14:52
  • 1313

三种读取XML方法

http://topic.csdn.net/u/20100819/16/f2fd30cf-8973-474b-8621-ce6f28bcd9a2.html回复该帖子得到如此多收获,这种感觉真是太妙了!...
  • luols
  • luols
  • 2010年08月20日 16:33
  • 2344

HTML读取xml文件的三种办法

刚开始学这里的时候有点懵,以前没学过。但是学安卓动画(Animation)的时候接触过xml文件,总体来说不难。 一般来说xml文件用来储存数据,然后html读取它,主要介绍三种读取方式 利用CSS读...
  • zhengyikuangge
  • zhengyikuangge
  • 2017年11月14日 23:13
  • 556

安卓读取assets中的xml文件

AssetManager asset = context.getAssets(); try { InputStream input = asset.open("...
  • rnZuoZuo
  • rnZuoZuo
  • 2015年10月26日 19:36
  • 1459

Android如何获取asset下的xml文件,并解析

1.asset下的自定义xml文件: Java Eclipse Swift Xcode ...
  • yuchen56
  • yuchen56
  • 2015年11月19日 11:42
  • 774

java读取XML文件的四种方式及比较

data A1234 四川省XX县XX镇XX路X段XX号 B1234 四川省XX市XX乡XX村XX组
  • so_sss
  • so_sss
  • 2014年11月08日 16:47
  • 4656
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:java环境下读取xml文件的方法
举报原因:
原因补充:

(最多只允许输入30个字)