xml解析之pull

Pull解析類似於SAX解析,也是基於事件的。

其解析用到的類很簡單,只有一接口XmlPullParser,一工廠XmlPullParserFactory,和一個異常。

基本步驟是:

一、得到工廠實例;

二、得到解析器實例;

三、設置解析器的數據流與編碼方式

四、通過循環加switch分支,處理五種基本的解析事件,即START_DOCUMENT,START_TAGEND_TAGEND_DOCUMENTTEXT。

示例XML代碼:

<?xml version="1.0" encoding="utf-8"?>
<persons>
    <person name="Claw" age="24">
        <weight>70kg</weight>
        <height>4325px</height>
    </person>
    <person name="Nancy" age="25">
        <weight>54kg</weight>
        <height>4300px</height>
    </person>
    <person name="dearcloud" age="27">
        <weight>55kg</weight>
        <height>4300px</height>
    </person>
</persons>
解析示例代碼如下:

public static List<Map<String, String>> parse(InputStream is, String encode) {
		List<Map<String, String>> list = null;
		Map<String, String> map = null;
		try {
			XmlPullParserFactory factory = XmlPullParserFactory.newInstance();
			XmlPullParser parser = factory.newPullParser();
			parser.setInput(is, encode);
			int eventType = parser.getEventType();
			while (eventType != XmlPullParser.END_DOCUMENT) {
				switch (eventType) {
				case XmlPullParser.START_DOCUMENT:
					list = new ArrayList<Map<String, String>>();
					break;
				case XmlPullParser.START_TAG:
					if (parser.getName().equals("person")) {
						map = new HashMap<String, String>();
						map.put("age", parser.getAttributeValue(0));
					} else if (parser.getName().equals("weight")) {
						map.put("weight", parser.nextText());
					} else if (parser.getName().equals("height")) {
						map.put("height", parser.nextText());
					}
					break;
				case XmlPullParser.END_TAG:
					if (parser.getName().equals("person")) {
						list.add(map);
					}
					break;
				default:
					break;
				}
				eventType = parser.next();
			}

		} catch (Exception e) {
			e.printStackTrace();
		}
		return list;

	}

用這個方法,傳入xml文件的流和節點名(和上篇同樣),就可以解析xml文件了。

發佈了41 篇原創文章 · 獲贊 1 · 訪問量 3萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章