XML是一种常见的传输数据方式,所以在开发中,我们会遇到对XML文件进行解析的时候,本篇主要介绍使用SAM解析器,对XML文件进行解析。

SAX解析器的长处是显而易见的。那就是SAX并不须要将全部的文档都载入内存之后才进行解析。SAX是事件驱动机制的。也就是碰到元素节点、文本节点、文档节点的时候。都会触发一定的事件。我们仅仅须要在对应的回调事件里面进行对应的处理就能够了。由于这个特点。所以SAX解析占用的内存比較少。其它的解析方式,比方下一节要介绍的DOM解析器。则占用内存比較多。在解析比較小的XML文件的时候,差别不是非常大。大家哪种顺手就能够用哪种。可是当须要解析的文档达到几百K以上的时候,还是推荐使用SAX解析器或者是PULL解析器。这几种XML的解析方式。我都会在以后的文章中进行介绍,今天重点看SAX解析器。

以下是我们要进行解析的文件格式

<?xml version="1.0" encoding="UTF-8"?>
<persons>
<person id="23">
<name>liming</name>
<age>30</age>
</person>
<person id="20">
<name>lixiangmei</name>
<age>25</age>
</person>
</persons>

以下是我们的实体类

public class Person {
private Integer id;
private String name;
private Short age; public Person(){} public Person(Integer id, String name, Short age) {
this.id = id;
this.name = name;
this.age = age;
} public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Short getAge() {
return age;
}
public void setAge(Short age) {
this.age = age;
}
@Override
public String toString() {
return "Person [age=" + age + ", id=" + id + ", name=" + name + "]";
} }

我们定义一个SAM解析器。对内容进行解析

/**
* 使用SAX对XML文件进行解析
*
* @author zhaokaiqiang
*
*/
public class SaxResolve { public List<Person> getPersons(InputStream inputStream) throws Exception { //获取SAXParser对象
SAXParser parser = SAXParserFactory.newInstance().newSAXParser();
//实例化我们的解析器
PersonHandler handler = new PersonHandler();
//開始对输入流解析
parser.parse(inputStream, handler);
//关闭输入流
inputStream.close();
//返回结果
return handler.getPersons();
} private class PersonHandler extends DefaultHandler { private List<Person> persons;
private Person person = null;
private String tag = null; public List<Person> getPersons() {
return persons;
} // 当读取到xml文件的開始部分时。对persons进行初始化
@Override
public void startDocument() throws SAXException {
persons = new ArrayList<Person>();
} // 这种方法对元素节点进行解析,如我们数据中的<person>、<age>、<name>都属于元素节点
// 当读取到person节点时,对Person对象进行初始化,同一时候获取到属性节点的值。并赋值给id,
// 记录如今的节点的名称,即localName,用于Person节点内部节点的解析
@Override
public void startElement(String uri, String localName, String qName,
Attributes attributes) throws SAXException {
if (localName.equals("person")) {
person = new Person();
person.setId(new Integer(attributes.getValue(0)));
}
tag = localName;
} // 这个回调方法用于对文本节点进行解析,如<age>30</age>里面的30就是属于文本节点。
// 我们依据元素节点tag的取值,取出里面的文本节点。然后对person进行赋值
@Override
public void characters(char[] ch, int start, int length)
throws SAXException { if (tag != null) {
String data = new String(ch, start, length);
if ("name".equals(tag)) {
person.setName(data);
} else if ("age".equals(tag)) {
person.setAge(new Short(data));
}
} } /*
* 当到达一个元素节点的结束时 比方
* <person id="20">
* <name>lixiangmei</name>
* <age>25</age>
* </person>
* 当到达这里的</person>节点,就会出发以下的事件,我们在这个回调方法里面将解析出的person对象
* 加入到persons里面,而且将person和tag进行初始化,进行下一个person节点的解析
*/
@Override
public void endElement(String uri, String localName, String qName)
throws SAXException {
if (localName.equals("person")) {
persons.add(person);
person = null;
}
tag = null;
} } }

由于凝视比較具体,所以只是多解析,以下我们使用单元測试,对解析进行測试

//測试SAX解析
public void testSax() throws Exception {
//从xml文件里获取输入流
InputStream inputStream = getClass().getClassLoader()
.getResourceAsStream("persons.xml");
//获取解析出的对象
List<Person> persons = new SaxResolve().getPersons(inputStream);
//打印
for (Person p : persons) {
Log.d(TAG, p.toString());
} }

以下是解析结果

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvYno0MTk5MjcwODk=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

解析XML文件之使用SAM解析器的更多相关文章

  1. 解析XML文件之使用DOM解析器

    在前面的文章中.介绍了使用SAX解析器对XML文件进行解析.SAX解析器的长处就是占用内存小.这篇文章主要介绍使用DOM解析器对XML文件进行解析. DOM解析器的长处可能是理解起来比較的直观,当然, ...

  2. Python解析xml文件遇到的编码解析的问题

    使用python对xml文件进行解析的时候,假设xml文件的头文件是utf-8格式的编码,那么解析是ok的,但假设是其它格式将会出现例如以下异常: xml.parsers.expat.ExpatErr ...

  3. dom4j生成和解析xml文件

    dom4j生成和解析xml文件 要生成和解析如下格式的xml文件: <?xml version="1.0" encoding="UTF-8"?> & ...

  4. java解析XML文件四种方法之引入源文件

    1.DOM解析(官方) try { DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();         Documen ...

  5. 使用XML序列化器生成XML文件和利用pull解析XML文件

    首先,指定XML格式,我指定的XML格式如下: <?xml version='1.0' encoding='utf-8' standalone='yes' ?> <message&g ...

  6. JAVA使用SAX解析XML文件

    在我的另一篇文章(http://www.cnblogs.com/anivia/p/5849712.html)中,通过一个例子介绍了使用DOM来解析XML文件,那么本篇文章通过相同的XML文件介绍如何使 ...

  7. XML:使用DOM技术解析xML文件中的城市,实现select级联选择

    中国的城市xml格式:cities.xml <?xml version="1.0" encoding="utf-8"?> <china> ...

  8. Android开发学习---使用XmlPullParser解析xml文件

    Android中解析XML的方式主要有三种:sax,dom和pull关于其内容可参考:http://blog.csdn.net/liuhe688/article/details/6415593 本文将 ...

  9. SAX解析xml文件

    需要做一个银行名字的列表. 因为有很多,所以想到了用xml来保存,然后uongDAX解析. public class BankSelectActivity extends BaseActivity{ ...

随机推荐

  1. 单元测试框架 unittest 的运行方法if __name__ == '__main__': unittest.main()

    1. if __name__ == '__main__': unittest.main()2. 测试用例实例根据测试的特点分组在一起. unittest为此提供了一个机制:测试套件由unittest' ...

  2. C#获取指定月指定周的日期范围

    );        MessageBox.Show(end.ToShortDateString());

  3. .Net主线程扑捉子线程中的异常

    首先看一段C#代码:运行后发现主线程通过try{}catch{}是不能扑捉子线程中的抛出来的异常. 代码 );        }        public void run()        {   ...

  4. [转载] hessian学习

    转载自http://www.cnblogs.com/yjmyzz/p/hessian-helloworld.html hessian是一个采用二进制格式传输的服务框架,相对传统soap web ser ...

  5. css基础-选择器

    CSS选择符(选择器) 一.各类选择器 选择符表示要定义样式的对象,可以是元素本身,也可以是一类元素或者制定名称的元素. 常用的选择符有十种左右 类型选择符,id选择符,class选择符,通配符,群组 ...

  6. Mysql 用法

    一转眼,一个星期过去了,来到测试班也一个星期了,今天经历了一次,这是自己这一周的总结,也算对自己这一周的一个交代. 几个比较重要的语句: 查看数据库 show databases; 创建数据库 cre ...

  7. 熊掌号:"搜索+信息流"双引擎与"百家号+熊掌号"双品牌内容平台

    一. 熊掌号是什么?熊掌号简单来说,就是"搜索 + 信息流"双引擎与"百家号 + 熊掌号"双品牌内容平台,上线了,对站长还是企业,都是一件好事.只要写出优质的原 ...

  8. 在PostgreSQL自定义一个“优雅”的type

    是的,又是我,不要脸的又来混经验了.我们知道PostgreSQL是一个高度可扩展的数据库,这次我聊聊如何在PostgreSQL里创建一个优雅的type,如何理解优雅?大概就是不仅仅是type本身,其它 ...

  9. 实战项目——mysql主从架构的实现

    一主一从 1.1 环境准备: centos系统服务器2台. 一台用户做Mysql主服务器, 一台用于做Mysql从服务器, 配置好yum源. 防火墙关闭. 各节点时钟服务同步. 各节点之间可以通过主机 ...

  10. 32.Linux-2440下的DMA驱动(详解)

    DMA(Direct Memory Access) 即直接存储器访问, DMA 传输方式无需 CPU 直接控制传输,通过硬件为 RAM .I/O 设备开辟一条直接传送数据的通路,能使 CPU 的效率大 ...