PULL 和 SAX 很相像,都是在节点中走,然后遇到开始节点了、结束节点会触发事件,此时就可以获取值。
import org.xmlpull.v1.XmlPullParser;import org.xmlpull.v1.XmlPullParserException;import java.io.ByteArrayInputStream;import java.io.IOException;import java.io.InputStream; try { String xml = "<?xml version=\"1.0\"?><root><siteName></siteName><siteUrl>http://www.cftea.com/</siteUrl></root>"; InputStream inputStream = new ByteArrayInputStream(xml.getBytes()); XmlPullParser parser = Xml.newPullParser(); parser.setInput(inputStream, "UTF-8"); int eventType = parser.getEventType(); while (eventType != XmlPullParser.END_DOCUMENT) { switch (eventType) { case XmlPullParser.START_DOCUMENT: break; case XmlPullParser.START_TAG: if (parser.getName().equals("siteName")) { parser.next(); // 注意这里 editText.setText(parser.getEventType() + ":" + parser.getName()); // 注意这里 } break; case XmlPullParser.END_TAG: break; default: break; } eventType = parser.next(); } inputStream.close(); } catch (XmlPullParserException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); }
本例中,我们故意将 siteName 的节点内容去掉,然后我们看看上述代码中“注意这里”那两行,通过监测,<siteName> 之后 parser.next 是移动到了 </siteName> 并不是移动到了空白节点值,所以上述代码不好,我们得优化一下。
int eventType = parser.getEventType(); String tagName = ""; while (eventType != XmlPullParser.END_DOCUMENT) { switch (eventType) { case XmlPullParser.START_DOCUMENT: break; case XmlPullParser.START_TAG: tagName = parser.getName(); break; case XmlPullParser.TEXT: if (tagName.equals("siteName")) { editText.setText(parser.getText()); } break; case XmlPullParser.END_TAG: tagName = ""; break; } eventType = parser.next(); }
可以看出 PULL 与 SAX 相比,PULL 是自己处理节点之间的移动,SAX 是自己移动,需要程序员去重写处理方法。
- Android 中处理 XML 的四种方式-DOM
- Android 中处理 XML 的四种方式-SAX
- Android 中处理 XML 的四种方式-PULL