pull解析xml文件,和sax和dom一样 都可以脱离android单独使用,pull和sax的原理一样,不一样的地方是pull读取xml文件后调用方法返回的是数字,
读取到xml的声明返回数字0 START_DOCUMENT;
读取到xml的结束返回数字1 END_DOCUMENT ;
读取到xml的开始标签返回数字2 START_TAG
读取到xml的结束标签返回数字3 END_TAG
读取到xml的文本返回数字4 TEXT
被解析的xml文档和Android dom 解析xml方式 中的xml文档一样,命名为pullTest.xml.
private String pullParseXml(InputStream inputStream) {
String result = "";
try {
// 获取一个解析实例
XmlPullParser parse = Xml.newPullParser();
// 设置输入流的编码格式
parse.setInput(inputStream, "UTF-8");
// 当前事件的类型
int eventType = parse.getEventType();
while (XmlPullParser.END_DOCUMENT != eventType) {
// 当前节点的名称
String nodeName = parse.getName();
switch (eventType) {
case XmlPullParser.START_TAG:
if ("group".equals(nodeName)) {
// 解析<group>节点中的属性值,getAttributeCount()获取属性的个数
for (int i = 0; i < parse.getAttributeCount(); i++) {
// 属性名称
String groupName = parse.getAttributeName(i);
// 属性名称对应的值
String nameValue = parse.getAttributeValue(i);
result = result + groupName + " = " + nameValue;
}
result += "\n";
} else if ("person".equals(nodeName)) {
String personName = parse.getAttributeValue(0);
} else if ("chinese".equals(nodeName)) {
//节点对应的文本
String chinese = parse.nextText();
result = result + "chinese = " + chinese;
} else if ("english".equals(nodeName)) {
String english = parse.nextText();
}
break;
case XmlPullParser.END_TAG:
//在解析到一个group节点完成时,退出解析xml文件
if("group".equals(nodeName)){
eventType = XmlPullParser.END_DOCUMENT;
}
break;
default:
break;
}
//下一个结点类型
eventType = parse.next();
}
} catch (Exception e) {
e.printStackTrace();
}
return result;
}