本篇博客重点介绍Android中三种解析XML的方式,包括PULL、SAX、DOM,当然不止这些,还可以用第三方的jar包提供的解析,只是这三种在Android中比较常用吧。再顺便介绍一下AndroidTestCase的用法,用来测试所写的解析业务逻辑是否正确。

本篇博客使用的xml文件如下:

student.xml

<?xml version="1.0" encoding="UTF-8"?>  <students>      <student id="1003">          <name>ZhangSan</name>          <age>23</age>        <score>89</score>      </student>    <student id="1004">          <name>LiSi</name>          <age>24</age>        <score>72</score>      </student>    <student id="1005">          <name>WangWu</name>          <age>25</age>        <score>79</score>      </student></students>

各字体属性应该很清楚了,这里不再介绍,也不是重点。

此xml文件放在Android工程下面的assets目录下面,等待解析。。。

再建一个类Student.java

package com.and.xml;

public class Student {

    private int id;    private String name;    private int age;    private float score;

    public Student() {        super();    }

    public Student(int id, String name, int age, float score) {        super();        this.id = id;        this.name = name;        this.age = age;        this.score = score;    }

    public int getId() {        return id;    }

    public void setId(int id) {        this.id = id;    }

    public String getName() {        return name;    }

    public void setName(String name) {        this.name = name;    }

    public int getAge() {        return age;    }

    public void setAge(int age) {        this.age = age;    }

    public float getScore() {        return score;    }

    public void setScore(float score) {        this.score = score;    }

    @Override    public String toString() {        // TODO Auto-generated method stub        return "Id:" + this.id + ",Name:" + this.name + ",Age" + this.age                + ",Score:" + this.score;    }}

下面分别介绍三种解析方式。

第一种:PULL解析

PullParseService.java

package com.and.xml;

import java.io.InputStream;import java.util.ArrayList;import java.util.List;

import org.xmlpull.v1.XmlPullParser;import org.xmlpull.v1.XmlPullParserFactory;/** * PULL解析示例 * @author Administrator * */public class PullParseService {    public static List<Student> getStudents(InputStream input) throws Exception {        List<Student> data = null;        Student stu = null;

        XmlPullParserFactory fac = XmlPullParserFactory.newInstance();        fac.setNamespaceAware(true);        XmlPullParser parser = fac.newPullParser();        parser.setInput(input, "UTF-8");        int eventType = parser.getEventType();        while (eventType != XmlPullParser.END_DOCUMENT) {            switch (eventType) {            case XmlPullParser.START_DOCUMENT:                System.out.println("START_DOCUMENT");                data = new ArrayList<Student>();                break;            case XmlPullParser.START_TAG:                if ("student".equals(parser.getName())) {                    stu = new Student();                    stu.setId(Integer.parseInt(parser.getAttributeValue(0)));                }                if (stu != null) {                    if ("name".equals(parser.getName())) {                        stu.setName(parser.nextText());                    } else if ("age".equals(parser.getName())) {                        stu.setAge(Integer.parseInt(parser.nextText()));                    } else if ("score".equals(parser.getName())) {                        stu.setScore(Float.parseFloat(parser.nextText()));                    }                }                break;            case XmlPullParser.END_TAG:                if ("student".equals(parser.getName())) {                    if (data != null && stu != null) {                        data.add(stu);                        stu = null;                    }                }                break;            }            eventType = parser.next();// 注意:此处勿要写成parser.next();不要理解成指针        }

        return data;    }}

至此,PULL解析的核心业务完成了,怎样来测试有没有问题呢?一般情况下,都是在Activity输出调试日志,根据调试日志判断是否解析成功。这里换一种方式,用Android的测试用例来测试一下。

TestParseService.java

package com.and.test;

import java.io.InputStream;import java.util.List;

import javax.xml.parsers.SAXParserFactory;

import org.xml.sax.InputSource;import org.xml.sax.XMLReader;

import com.and.xml.DomParseService;import com.and.xml.PullParseService;import com.and.xml.SaxParserService;import com.and.xml.Student;

import android.test.AndroidTestCase;import android.util.Log;

/** * 测试三种解析方式(Pull、SAX、Dom) *  * @author And 2012-02-29 */public class TestParseService extends AndroidTestCase {    private static final String TAG = "testService";    InputStream input;    List<Student> students;

    public void init() throws Exception {        input = this.getContext().getAssets().open("students.xml");    }

    // 测试Pull解析方式    public void testPull() throws Exception {        init();        students = PullParseService.getStudents(input);        for (Student stu : students) {            Log.i(TAG, stu.toString());        }    }

    // 测试SAX解析方式    public void testSAX() throws Exception {        init();        SAXParserFactory fac = SAXParserFactory.newInstance();        XMLReader reader = fac.newSAXParser().getXMLReader();        SaxParserService saxHandler = new SaxParserService();        reader.setContentHandler(saxHandler);        reader.parse(new InputSource(input));        students = saxHandler.getParseData();        for (Student stu : students) {            Log.i(TAG, stu.toString());        }    }

    // 测试DOM解析方式    public void testDom() throws Exception {        init();        students = DomParseService.getPersonsByParseXml(input);        for (Student stu : students) {            Log.i(TAG, stu.toString());        }    }

}

注意一定要继承自AndroidTestCase这个类。这个文件中写了所有三种解析的测试方法,其它的忽视吧,只看testPull方法,它是用来测试上面所写的PULL解析业务的 。

那么怎样测试呢?

鼠标选中testPull方法名——>右键——>Run As——>Anroid JUnit Test

会提示以下错误:

大概意思就是没有配置running tests.控制台输出:

XmlParseDemo does not specify a android.test.InstrumentationTestRunner instrumentation or does not declare uses-library android.test.runner in its AndroidManifest.xml

从上面的提示信息可知,需要在AndroidManifest.xml中作一些配置,包括instrumentation和uses-library的配置

在AndroidManifest.xml文件中添加如下两行

<instrumentation android:targetPackage="com.and.xml" android:name="android.test.InstrumentationTestRunner"></instrumentation>
<uses-library android:name="android.test.runner"/>

注意添加位置:

第一句跟application节点同级。

第二句跟activity同级。

上面介绍的方法是手动代码添加,下面介绍一种图形化的方式,只需要点击鼠标就可以搞定。

打开AndroidManifest.xml文件

点击Add...

这样,use-library就添加好了

同样的方法添加instrumentation属性

注意Target package后面的内容:com.and.xml包

整个工程目录结构如图:

然后查看一下AndroidManifest.xml的内容,已经包含了刚才添加的那两句了:

<?xml version="1.0" encoding="utf-8"?><manifest xmlns:android="http://schemas.android.com/apk/res/android"    package="com.and.xml"    android:versionCode="1"    android:versionName="1.0" >

    <uses-sdk android:minSdkVersion="7" />    <instrumentation android:targetPackage="com.and.xml" android:name="android.test.InstrumentationTestRunner"></instrumentation>

    <application        android:icon="@drawable/ic_launcher"        android:label="@string/app_name" >        <activity            android:label="@string/app_name"            android:name="com.and.xml.MainActivity" >            <intent-filter >                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />            </intent-filter>        </activity>        <uses-library android:name="android.test.runner"/>    </application>

</manifest>

OK,然后继续之前的操作“鼠标选中testPull方法名——>右键——>Run As——>Anroid JUnit Test”

如果出现类似这样的页面,就表示测试用例建立成功,并且测试方法通过

左上角的绿色条,表示测试方法通过,右下角的调试日志输出,通过判断可以知道解析成功。

第二种:SAX解析

SaxParserService.java

package com.and.xml;

import java.util.ArrayList;import java.util.List;

import org.xml.sax.Attributes;import org.xml.sax.SAXException;import org.xml.sax.helpers.DefaultHandler;

/** * SAX解析示例 *  * @author Administrator *  */public class SaxParserService extends DefaultHandler {

    List<Student> data = null;    Student stu = null;    String tag = "";

    @Override    public void characters(char[] ch, int start, int length) throws SAXException {        super.characters(ch, start, length);        if (stu != null) {            String str = new String(ch, start, length);            if (tag.equals("name")) {                stu.setName(str);            } else if (tag.equals("age")) {                stu.setAge(Integer.parseInt(str));            } else if (tag.equals("score")) {                stu.setScore(Float.parseFloat(str));            }        }    }

    @Override    public void endDocument() throws SAXException {        super.endDocument();    }

    @Override    public void endElement(String uri, String localName, String qName)            throws SAXException {        super.endElement(uri, localName, qName);        if (localName.equals("student") && stu != null) {            data.add(stu);            stu = null;        }        tag = "";    }

    @Override    public void startDocument() throws SAXException {        super.startDocument();        data = new ArrayList<Student>();    }

    @Override    public void startElement(String uri, String localName, String qName,            Attributes attributes) throws SAXException {        super.startElement(uri, localName, qName, attributes);        tag = localName;        if (localName.equals("student")) {            stu = new Student();        }        if (attributes.getValue(0) != null) {            stu.setId(Integer.parseInt(attributes.getValue(0)));        }    }

    public List<Student> getParseData() {        return data;    }

}

注意一定要继承自DefaultHandler,然复写里面的方法,这些方法名字根据字面意思很容易理解它的作用。

然后通过上面的的测试文件,按照类似的方法测试一下testSAX()方法,如果出现绿条和日志输出的话,表明解析业务逻辑成功。

第三种:DOM解析

DomParseService.java

package com.and.xml;

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;

/** * DOM解析示例 *//** * DOM解析器在解析XML文档时,会把文档中的所有元素,按照其出现的层次关系,解析成一个个Node对象(节点)。Node对象提供了一系列常量来代表结点的类型 * ,当开发人员获得某个Node类型后,就可以把Node节点转换成相应节点对象(Node的子类对象),以便于调用其特有的方法。 * Node对象提供了相应的方法去获得它的父结点或子结点。编程人员通过这些方法就可以读取整个XML文档的内容、或添加、修改、删除XML文档的内容. *  * 缺点: 一次性的完全加载整个xml文件,需要消耗大量的内存。 */public class DomParseService {

    public static List<Student> getPersonsByParseXml(InputStream is) throws Exception {        List<Student> persons = new ArrayList<Student>();        DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();        try {            DocumentBuilder builder = factory.newDocumentBuilder();            Document document = builder.parse(is);            Element root = document.getDocumentElement();            NodeList items = root.getElementsByTagName("student");// 得到所有person节点            for (int i = 0; i < items.getLength(); i++) {                Student Student = new Student();                Element personNode = (Element) items.item(i);                Student.setId(new Integer(personNode.getAttribute("id")));                // 获取person节点下的所有子节点(标签之间的空白节点和name/age元素)                NodeList childsNodes = personNode.getChildNodes();                for (int j = 0; j < childsNodes.getLength(); j++) {                    Node node = (Node) childsNodes.item(j); // 判断是否为元素类型                    if (node.getNodeType() == Node.ELEMENT_NODE) {                        Element childNode = (Element) node;                        // 判断是否name元素                        if ("name".equals(childNode.getNodeName())) {                            // 获取name元素下Text节点,然后从Text节点获取数据                            Student.setName(childNode.getFirstChild().getNodeValue());                        } else if ("age".equals(childNode.getNodeName())) {                            Student.setAge(new Short(childNode.getFirstChild().getNodeValue()));                        } else if ("score".equals(childNode.getNodeName())) {                            Student.setScore(Float.parseFloat(childNode.getFirstChild().getNodeValue()));                        }                    }                }                persons.add(Student);            }            is.close();        } catch (Exception e) {            e.printStackTrace();        }        return persons;    }}

xml的三种解析方式相关推荐

  1. xml文件的三种解析方式 DOM SAM PULL

    <?xml version="1.0" encoding="UTF-8"?> <root><student id="1& ...

  2. JSON的三种解析方式以及JSONObject、JSONArray区别

    JSON的常用两种解析方式 一.什么是JSON? JSON是一种取代XML的数据结构,和xml相比,它更小巧但描述能力却不差,由于它的小巧所以网络传输数据将减少更多流量从而加快速度. JSON就是一串 ...

  3. Android中XML的三种解析器分析、实战

    XML解析器介绍 Android中提供了三种方式来解析XML: SAX(simple API for XML) DOM(文档对象模型) 以及Android内部使用的Pull解析. SAX(simple ...

  4. xml的两种解析方式:sax,dom4j

    两种解析方式的优缺点:     sax解析:优点:不需要读取整个文件,并且将其储存在内从中,不耗费内存资源,才用触发监听的方式,文件读到哪里触发相应方法.         缺点:不能反复调用,每次解析 ...

  5. Android解析XML的三种方式

    在Android中提供了三种解析XML的方式:DOM(Document Objrect Model),SAX(Simple API XML),以及Android推荐的Pull解析方式. 如图: 本篇博 ...

  6. Java处理XML的三种主流技术及介绍

    Java处理XML的三种主流技术及介绍(1) 2012-08-15 10:44 顾彬/冯晨/乔彬 IBM developerWorks 我要评论(0) 字号:T | T XML (eXtensible ...

  7. Java解析Xml的三种方式总结

    转自:http://blog.csdn.net/zjf280441589/article/details/50613881 XML解析技术有两种 DOM SAX DOM方式  根据XML的层级结构在内 ...

  8. 用python解析xml的几种方法,Python_XML的三种解析方法

    什么是XML? XML 指可扩展标记语言(eXtensible Markup Language). XML 被设计用来传输和存储数据. XML是一套定义语义标记的规则,这些标记将文档分成许多部件并对这 ...

  9. java解析xml的三种方法

    java解析XML的三种方法 1.SAX事件解析 package com.wzh.sax;import org.xml.sax.Attributes; import org.xml.sax.SAXEx ...

最新文章

  1. 专访百度熊辉:有人转AI纯粹因为好找工作,这样的人不是我想要的
  2. Java基础--多线程
  3. android 设置默认铃声,Android系统修改默认铃声
  4. freemaker .flt文件自动换行的问题,map循环获取key和value
  5. 社交游戏Zynga之死
  6. 问题五十一:怎么用ray tracing画tear drop
  7. Java求100以内素数和
  8. linux fedora14 u盘运行,通过U盘安装Fedora-14-i686-Live-Desktop
  9. html制作dnf,DNF教你如何不花一分钱制作90顶级史诗
  10. python写一个网络测速脚本_网络测速工具——Speedtest
  11. Ubuntu 重新安装声卡驱动
  12. 个体营业执照与公司营业执照的区别
  13. html5光线传感器,光线传感器是什么 光线传感器分类
  14. GetLocalTime 和 GetSystemTime 的区别
  15. 圣墟手游怎么在电脑上玩 圣墟PC版玩法教程
  16. 关于初始化数据库时报错及解决办法(常见故障整理)
  17. 读后感《孤独的张小龙,在商业中走出孤独》
  18. java导出word实现方式一,在jsp中实现
  19. 学业水平考试b能上985吗_哪些大学对会考等级有要求
  20. 全球及中国工程机械行业销售规模与投资竞争力研究报告2022版

热门文章

  1. SQuirrel SQL Client数据库连接工具的配置与使用
  2. 归并排序【算法解析,代码模板】
  3. 错误1053: 服务没有及时地响应启动或控制请求
  4. 使用TFS2010管理敏捷项目生命周期-系列指南5 TFS 故事墙(Story Wall)-看板(Dashboard)-Workbrench使用
  5. 初识 CGI,CGI 简识
  6. DIV display visibility
  7. EventLog Analyzer应用程序日志管理
  8. 某些软件中,输入法无法输入中文
  9. windows计划任务执行powershell脚本
  10. kernel panic