java中采用Pull解析器對XML文件進行解析
一、基本介紹
Android中極力推薦xmlpull方式解析xml。
xmlpull不僅可用在Android上同樣也適用於javase,但在javase環境中需自己獲取xmlpull所依賴的類庫,kxml2-2.3.0.jar,xmlpull_1_1_3_4c.jar。
jar包下載網址
https://www.xmlpull.org/
https://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 > <name>XY1</name> <age>22</age> </person> <person > <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; } }
最後更新:2017-04-03 05:40:35