xml文件解析

xml是用于存储配置信息的文件。说到底xml文件就是一棵树,一颗大大的树,能存储很多关系型的信息。有时候需要对xml文件进行读写等操作,那么有什么方法可以对其进行读写呢?

主要有两种方式:一、使用DOM4J解析包对其进行读写   二.使用SAX解析包对其进行读取,不可写入

一,DOM4J解析包解析xml文档(读写)

主要分为一下几个步骤:

1.获取DOM解析器。DocumentBuilder documentBuilder=DocumentBuilderFactory.newInstance().newDocumentBuilder();

2.加载xml文档。Document document=documentBuilder.parse("src/exam.xml");

3.创建或者获取元素节点:Element nodeStudent=document.createElement("Student");   //获取可以使用相应的getXXX方法

4.写入到xml文档:Transformer tf=TransformerFactory.newInstance().newTransformer();
   tf.transform(new DOMSource(document), new StreamResult("src/exam.xml"));

 

在使用DOM解析xml时,java中提供了很多方法来操作xml文档,方法大体上与javascript中获取元素节点和创建节点类似,没有很大区别

 

二、SAX解析xml文档

主要有一下几个步骤:

1.获取SAX解析器

2.获取XML读取器

3.注册内容处理器

4.加载xml文档

 

实例:演示SAX解析的时机

package com.sax_parser;

import java.io.IOException;

import javax.xml.parsers.ParserConfigurationException;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;

import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.XMLReader;
import org.xml.sax.helpers.DefaultHandler;
/**
 * 演示SAX解析的各个时机
 * @author Administrator
 *
 */
public class SaxParser {

 /**
  * @param args
  * @throws SAXException
  * @throws ParserConfigurationException
  * @throws IOException
  */
 public static void main(String[] args) throws ParserConfigurationException, SAXException, IOException {
  // TODO Auto-generated method stub
  //创建一个解析器
  SAXParser sax=SAXParserFactory.newInstance().newSAXParser();
  //获取读取器
  XMLReader reader=sax.getXMLReader();
  //注册内容处理器
  reader.setContentHandler(new DefaultHandler(){
   /**
    * 开始读取xml文档时调用
    */
   @Override
   public void startDocument() throws SAXException {
    // TODO Auto-generated method stub
    System.out.println("开始读取文档了");
   }
   /**
    * 读取完xml文档时调用
    */
   @Override
   public void endDocument() throws SAXException {
    // TODO Auto-generated method stub
    System.out.println("文档读取结束了");
   }
   /**
    * 读取标签元素的开始标志
    */
   @Override
   public void startElement(String uri, String localName,
     String qName, Attributes attributes) throws SAXException {
    // TODO Auto-generated method stub
    System.out.println(qName+"----标签开始读取了");
   }
   /**
    * 读取标签元素的结束标志
    */
   @Override
   public void endElement(String uri, String localName, String qName)
     throws SAXException {
    // TODO Auto-generated method stub
    System.out.println(qName+"----标签读取结束了");
   }
   /**
    * 读取标签内容
    */
   @Override
   public void characters(char[] ch, int start, int length)
     throws SAXException {
    System.out.println("读取到的字符是==="+new String(ch,start,length));
   }
   
  });
  //加载文档
  reader.parse("src/exam.xml");
 }

}

读取xml文档主要有这两种技术,但他们又有所区别,DOM技术是解析整个xml文档后再读写,读写速度快,但占用大量的内存空间。SAX是边解析边读取,占用内存不大,但效率低些

 

发布了66 篇原创文章 · 获赞 13 · 访问量 9万+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章