1.使用pull解析

 package com.example.myxml;

 import java.io.InputStream;
import java.util.ArrayList;
import java.util.List; import org.xmlpull.v1.XmlPullParser;
import org.xmlpull.v1.XmlPullParserFactory; import android.util.Log;
import android.util.Xml; public class Pullparser { public static List<Person> getPerson(InputStream inStream) throws Exception {
List<Person> psonList = new ArrayList<Person>();
Person person = null;
XmlPullParser xmlParse = Xml.newPullParser();
try {
xmlParse.setInput(inStream, "utf-8");
int evnType = xmlParse.getEventType();
while (evnType != XmlPullParser.END_DOCUMENT) {
switch (evnType) {
case XmlPullParser.START_TAG:
String tag = xmlParse.getName();
if (tag.equalsIgnoreCase("person")) {
person = new Person();
person.setId(Integer.parseInt(xmlParse.getAttributeValue(0)));
} else if (person != null) {
// parse after tag
if (tag.equalsIgnoreCase("name")) {
person.setName(xmlParse.nextText());
} else if (tag.equalsIgnoreCase("age")) {
person.setAge(xmlParse.nextText());
}
}
break;
case XmlPullParser.END_TAG:
if (xmlParse.getName().equalsIgnoreCase("person")
&& person != null) {
psonList.add(person);
person = null;
}
break;
default:
break;
}
evnType = xmlParse.next();
}
} catch (Exception e) {
}
return psonList;
}
}

2.使用DOM解析

package com.example.myxml;

import java.io.InputStream;
import java.util.ArrayList;
import java.util.List; import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory; import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList; import android.annotation.SuppressLint; public class DOMparser { @SuppressLint("UseValueOf")
public static List<Person> parse(InputStream inStream) throws Exception {
List<Person> persons = new ArrayList<Person>();
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
Document document = builder.parse(inStream);
Element root = document.getDocumentElement();
NodeList personNodes = root.getElementsByTagName("person");
for (int i = 0; i < personNodes.getLength(); i++) {
Element personElement = (Element) personNodes.item(i);
int id = new Integer(personElement.getAttribute("id"));
Person person = new Person();
person.setId(id);
NodeList childNodes = personElement.getChildNodes();
for (int y = 0; y < childNodes.getLength(); y++) {
if (childNodes.item(y).getNodeType() == Node.ELEMENT_NODE) {
if ("name".equals(childNodes.item(y).getNodeName())) {
String name = childNodes.item(y).getFirstChild().getNodeValue();
person.setName(name);
}else if ("age".equals(childNodes.item(y).getNodeName())) {
String age = childNodes.item(y).getFirstChild().getNodeValue();
person.setAge(age);
}
}
}
persons.add(person);
}
inStream.close();
return persons;
}
}

3.使用SAX解析

package com.example.myxml;

import java.util.ArrayList;
import java.util.List; import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler; import android.annotation.SuppressLint; public class SAXparser extends DefaultHandler {
private List<Person> persons;
private Person person;
private String preTAG; @Override
public void startDocument() throws SAXException {
persons = new ArrayList<Person>();
} @Override
public void characters(char[] ch, int start, int length)throws SAXException {
if (person != null) {
String data = new String(ch, start, length);
if ("name".equals(preTAG)) {
person.setName(data);
} else if ("age".equals(preTAG)) {
person.setAge(data);
}
}
} @SuppressLint("UseValueOf")
@Override
public void startElement(String uri, String localName, String qName,
Attributes attributes) throws SAXException {
if ("person".equals(localName)) {
person = new Person();
person.setId(new Integer(attributes.getValue(0)));
}
preTAG = localName;
} @Override
public void endElement(String uri, String localName, String qName)
throws SAXException {
if ("person".equals(localName) && person != null) {
persons.add(person);
person = null;
}
preTAG = null;
} public List<Person> getPersons() {
return persons;
}
}

案例辅助代码

xML文件

<?xml version="1.0" encoding="UTF-8"?>
<persons>
<person id="23">
<name>张三</name>
<age>54</age>
</person>
<person id="20">
<name>小明</name>
<age>266</age>
</person>
</persons>

读取本地XML文件流

package com.example.myxml;

import java.io.InputStream;
import java.util.List; import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory; import android.os.Bundle;
import android.support.v7.app.ActionBarActivity;
import android.widget.TextView;
import android.widget.Toast; public class MainActivity extends ActionBarActivity {
TextView resultView;
List<Person> personList;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); resultView = (TextView) findViewById(R.id.result);
InputStream inStream = MainActivity.class.getClassLoader().getResourceAsStream("personxml.xml");
// SAX_Parser(inStream);
// DOM_Parser(inStream);
PULL_Parser(inStream);
visity();
} private void PULL_Parser(InputStream inStream) {
try {
personList= Pullparser.getPerson(inStream);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
} private void DOM_Parser(InputStream inStream) {
try {
personList = DOMparser.parse(inStream);
} catch (Exception e) {
e.printStackTrace();
}
} private void SAX_Parser(InputStream inStream) {
try {
// 得到SAX解析器的工厂实例
SAXParserFactory spf = SAXParserFactory.newInstance();
// 从SAX工厂实例中获得SAX解析器
SAXParser saxParser = spf.newSAXParser();
SAXparser handler = new SAXparser();
saxParser.parse(inStream, handler);
inStream.close(); personList = handler.getPersons();
} catch (Exception e) {
}
}
public void visity(){
if(personList!=null){
StringBuilder sb = new StringBuilder();
for (Person person : personList) {
sb.append(person.toString()).append("\n");
}
resultView.setText(sb.toString());
}else{
Toast.makeText(getApplicationContext(), "null", 0).show();
} }
}

android XML解析器全解案例的更多相关文章

  1. Android XML解析器的问题

    最近在项目中遇到了一个解析XML的问题,我们是用android自带的DOM解析器来解析XML的,但发现了一个android的问题,那就是在2.3的SDK上面,无法解析像<, >, 等字符串 ...

  2. Android xml 解析

    XML 经常使用的三种解析方式: DOM: 所有载入到内存,生成一个树状结构,占用内存比較大. SAJ: 採用事件驱动,速度快,效率高,不支持回退. PULL:也是採用事件驱动,语法简洁. 步骤: 1 ...

  3. Android] Android XML解析学习——方式比较

     [Android] Android XML解析学习——方式比较 (ZT)  分类: 嵌入式 (From:http://blog.csdn.net/ichliebephone/article/deta ...

  4. Solr系列五:solr搜索详解(solr搜索流程介绍、查询语法及解析器详解)

    一.solr搜索流程介绍 1. 前面我们已经学习过Lucene搜索的流程,让我们再来回顾一下 流程说明: 首先获取用户输入的查询串,使用查询解析器QueryParser解析查询串生成查询对象Query ...

  5. Duilib源码分析(三)XML解析器—CMarkup

    上一节介绍了控件构造器CDialogBuilder,接下来将分析其XML解析器CMarkup: CMarkup:xml解析器,目前内置支持三种编码格式:UTF8.UNICODE.ASNI,默认为UTF ...

  6. tinyxml一个优秀的C++ XML解析器

    读取和设置xml配置文件是最常用的操作,试用了几个C++的XML解析器,个人感觉TinyXML是使用起来最舒服的,因为它的API接口和Java的十分类似,面向对象性很好. TinyXML是一个开源的解 ...

  7. TinyXML:一个优秀的C++ XML解析器

    //-------------------------------------------------------------------------------------------------- ...

  8. 转:TinyXM--优秀的C++ XML解析器

    读取和设置xml配置文件是最常用的操作,试用了几个C++的XML解析器,个人感觉TinyXML是使用起来最舒服的,因为它的API接口和Java的十分类似,面向对象性很好. TinyXML是一个开源的解 ...

  9. android XMl 解析神奇xstream 六: 把集合list 转化为 XML文档

    前言:对xstream不理解的请看: android XMl 解析神奇xstream 一: 解析android项目中 asset 文件夹 下的 aa.xml 文件 android XMl 解析神奇xs ...

随机推荐

  1. Block编程值得注意的那些事儿

    [深入浅出Cocoa]Block编程值得注意的那些事儿   [深入浅出Cocoa]Block编程值得注意的那些事儿 罗朝辉 (http://www.cnblogs.com/kesalin/) 本文遵循 ...

  2. ACM -二分图题目小结

    暂时只包括与最大匹配相关的问题. 求最大独立集,最小路径覆盖等等大多数题目都可以转化为求最大匹配用匈牙利算法解决. 1.最大匹配(边集) 此类问题最直接,直接用匈牙利算法即可. HDU 2063  过 ...

  3. html5 placeholder

    placeholder是html5<input>标签的一个属性,placeholder 属性提供可描述输入字段预期值的提示信息(hint).该提示会在输入字段为空时显示,并会在字段获得焦点 ...

  4. CentOS中vsftp安装与配置

    http://blog.chinaunix.net/uid-7271021-id-3086186.html 553 Could not create file 解决办法 [root@localhost ...

  5. IOS第三方库 MARK

    综合github上各个项目的关注度与具体使用情况,涵盖功能,UI,数据库,自动化测试,编程工具等类型,看完,还敢自称”精通iOS开发”吗? https://github.com/syedhali/EZ ...

  6. 作业3-个人项目<词频统计>

    上了一天的课,现在终于可以静下来更新我的博客了.       越来越发现,写博客是一种享受.来看看这次小林老师的“作战任务”.                词频统计 单词: 包含有4个或4个以上的字 ...

  7. 圆角button

    方案1: <Window.Resources> <ControlTemplate x:Key="CornerButton" TargetType="{x ...

  8. Unity3d Shader

    Unity3d Shader 预览Surface Shader主要用来实现光照相关处理,可能更简洁. Vertex and Fragment Shader 如果不与光照交互, 则可以用这个shader ...

  9. Hadoop no.1

    解决的问题: 1. 磁盘读取速度慢:磁盘容量大了,将一个大的文件存在磁盘上,但读取速度慢.    解决方法:hdfs将文件拆开存在不同的节点(datanode)上,namenode记载文件存储的位置( ...

  10. vs2013 c++代码内出现中文导致编译错误

    简单的做法就是,首先,菜单栏->文件->高级保存选项,选择utf-8 无签名, 然后,如果是发现注释语句里有中文,可以让注释语句与下行代码中间空一行, 如果是代码里有用到中文,那么就在中文 ...