加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

xml文件解析

发布时间:2020-12-16 00:21:48 所属栏目:百科 来源:网络整理
导读:xml是用于存储配置信息的文件。说到底xml文件就是一棵树,一颗大大的树,能存储很多关系型的信息。有时候需要对xml文件进行读写等操作,那么有什么方法可以对其进行读写呢? 主要有两种方式:一、使用DOM4J解析包对其进行读写 二.使用SAX解析包对其进行读取

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 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是边解析边读取,占用内存不大,但效率低些

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读