在android
中解析
android
主要有
2
种方法,分别是
sax
和
jdom
第一种:SAX
是一个解析速度快并且占用内存少的
xml
解析器,非常适合用于
Android
等移动设备。
SAX
解析
XML
文件采用的是事件驱动,也就是说,它并不需要解析完整个文档,在按内容顺序解析文档的过程中,
SAX
会判断当前读到的字符是否合法
XML
语法中的某部分,如果符合就会触发事件。所谓事件,其实就是一些回调(
callback
)方法,这些方法
(
事件
)
定义在
ContentHandler
接口。下面是一些
ContentHandler
接口常用的方法:
startDocument()
当遇到文档的开头的时候,调用这个方法,可以在其中做一些预处理的工作。
endDocument()
和上面的方法相对应,当文档结束的时候,调用这个方法,可以在其中做一些善后的工作。
startElement(String namespaceURI, String localName, String qName, Attributes atts)
当读到一个开始标签的时候,会触发这个方法。namespaceURI
就是命名空间,
localName
是不带命名空间前缀的标签名,
qName
是带命名空间前缀的标签名。通过
atts
可以得到所有的属性名和相应的值。要注意的是
SAX
中一个重要的特点就是它的流式处理,当遇到一个标签的时候,它并不会纪录下以前所碰到的标签,也就是说,在
startElement()
方法中,所有你所知道的信息,就是标签的名字和属性,至于标签的嵌套结构,上层标签的名字,是否有子元属等等其它与结构相关的信息,都是不得而知的,都需要你的程序来完成。这使得
SAX
在编程处理上没有
DOM
来得那么方便。
endElement(String uri, String localName, String name)
这个方法和上面的方法相对应,在遇到结束标签的时候,调用这个方法。
characters(char[] ch, int start, int length)
这个方法用来处理在XML
文件中读到的内容,第一个参数用于存放文件的内容,后面两个参数是读到的字符串在这个数组中的起始位置和长度,使用
new String(ch,start,length)
就可以获取内容。
只要为SAX
提供实现
ContentHandler
接口的类,那么该类就可以得到通知事件(实际上就是
SAX
调用了该类中的回调方法)。因为
ContentHandler
是一个接口,在使用的时候可能会有些不方便,因此,
SAX
还为其制定了一个
Helper
类:
DefaultHandler
,它实现了这个接口,是个空实现类,运用了
java
设计模式中的适配器模式,我们在使用中只要继承这个类就可以了。
以下具体事例:
MP3.XMl
<?xml version="1.0" encoding="UTF-8"?>
<resources>
<resource>
<id>0001</id>
<mp3.name>我
.mp3</mp3.name>
<mp3.size>2056192</mp3.size>
<lrc.name>我
.lrc</lrc.name>
<lrc.size>4096</lrc.size>
</resource>
<resource>
<id>0002</id>
<mp3.name>永远的兄弟
.mp3</mp3.name>
<mp3.size>2916352</mp3.size>
<lrc.name>永远的兄弟
.lrc</lrc.name>
<lrc.size>4096</lrc.size>
</resource>
</resources>
Mp3Info类:
package
com.wp.pojo;
/**
* MP3实体类
*
@author
wangpeng
*
*/
public
class
Mp3Info {
private
String
id
;
private
String
mp3Name
;
private
String
mp3Size
;
private
String
lrcName
;
private
String
lrcSize
;
public
String getId() {
return
id
;
}
public
void
setId(String id) {
this
.
id
= id;
}
public
String getMp3Name() {
return
mp3Name
;
}
public
void
setMp3Name(String mp3Name) {
this
.
mp3Name
= mp3Name;
}
public
String getMp3Size() {
return
mp3Size
;
}
public
void
setMp3Size(String mp3Size) {
this
.
mp3Size
= mp3Size;
}
public
String getLrcName() {
return
lrcName
;
}
public
void
setLrcName(String lrcName) {
this
.
lrcName
= lrcName;
}
public
String getLrcSize() {
return
lrcSize
;
}
public
void
setLrcSize(String lrcSize) {
this
.
lrcSize
= lrcSize;
}
public
Mp3Info(String id, String mp3Name, String mp3Size, String lrcName,
String lrcSize) {
super
();
this
.
id
= id;
this
.
mp3Name
= mp3Name;
this
.
mp3Size
= mp3Size;
this
.
lrcName
= lrcName;
this
.
lrcSize
= lrcSize;
}
public
Mp3Info() {
super
();
}
@Override
public
String toString() {
return
"Mp3Info [id="
+
id
+
", lrcName="
+
lrcName
+
", lrcSize="
+
lrcSize
+
", mp3Name="
+
mp3Name
+
", mp3Size="
+
mp3Size
+
"]"
;
}
}
解析的部分方法,写读取为字符串
private
List<Mp3Info> parse(String
xmlStr
) {
SAXParserFactory saxParser = SAXParserFactory.
newInstance
();
List<Mp3Info> infos =
new
ArrayList<Mp3Info>();
try
{
XMLReader reader = saxParser.newSAXParser().getXMLReader();
Mp3ListContentHandler handler =
new
Mp3ListContentHandler(infos);
reader.setContentHandler(handler);
reader.parse(
new
InputSource(
new
StringReader(
xmlStr
)));
for
(Iterator<Mp3Info> iterator = infos.iterator(); iterator.hasNext();) {
Mp3Info info = iterator.next();
System.
out
.println(info.toString());
}
}
catch
(Exception e) {
e.printStackTrace();
}
return
infos;
}