一、基本介紹 Android中極力推薦xmlpull方式解析xml。
xmlpull不僅可用在Android上同樣也適用於javase,但在javase環境中需自己獲取xmlpull所依賴的類庫,kxml2-2.3.0.jar,xmlpull_1_1_3_4c.jar。
jar包下載網址
http://www.xmlpull.org/
http://kxml.sourceforge.net/
二、例子 讀取到xml的聲明返回數字0 START_DOCUMENT;
讀取到xml的結束返回數字1 END_DOCUMENT ;
讀取到xml的開始標簽返回數字2 START_TAG
讀取到xml的結束標簽返回數字3 END_TAG
讀取到xml的文本返回數字4 TEXT
復制代碼 代碼如下:
<?xml version="1.0" encoding="UTF-8"?>
<people>
<person id="001">
<name>XY1</name>
<age>22</age>
</person>
<person id="002">
<name>XY2</name>
<age>22</age>
</person>
</people>
復制代碼 代碼如下:
public class PersonService
{
/**
* 從XML文件中讀取數據
*
* @param xml XML文件輸入流
*/
public List<Person> getPeople(InputStream xml) throws Exception
{
List<Person> lst = null;
Person person = null;
// 獲得pull解析器工廠
XmlPullParserFactory pullParserFactory = XmlPullParserFactory.newInstance();
//獲取XmlPullParser的實例
XmlPullParser pullParser = pullParserFactory.newPullParser();
// 設置需要解析的XML數據
pullParser.setInput(xml, "UTF-8");
// 取得事件
int event = pullParser.getEventType();
// 若為解析到末尾
while (event != XmlPullParser.END_DOCUMENT) // 文檔結束
{
// 節點名稱
String nodeName = pullParser.getName();
switch (event)
{
case XmlPullParser.START_DOCUMENT: // 文檔開始
lst = new ArrayList<Person>();
break;
case XmlPullParser.START_TAG: // 標簽開始
if ("person".equals(nodeName))
{
String id = pullParser.getAttributeValue(0);
person = new Person();
person.setId(id);
}
if ("name".equals(nodeName))
{
String name = pullParser.nextText();
person.setName(name);
}
if ("age".equals(nodeName))
{
int age = Integer.valueOf(pullParser.nextText());
person.setAge(age);
}
break;
case XmlPullParser.END_TAG: // 標簽結束
if ("person".equals(nodeName))
{
lst.add(person);
person = null;
}
break;
}
event = pullParser.next(); // 下一個標簽
}
return lst;
}
}