Android的XML文件解析之PULL解析

简介: Android的XML文件解析之PULL解析

Android的XML文件解析之PULL解析

      我是一个在校大学生,对安卓的学习完全是出于兴趣,因此,只能靠自己自学,有写的不好的地方希望大家多多包涵。

首先说明本人写博客的目的,完全是为了对自己Android学习的总结,如果文章对你的学习和工作有所帮助,本人不胜荣幸。

当然,要解析XML文件,首先要有一个XML文件,下面我们自己新建一个XML文件,就以example.xml来命名一个文件。文件内容如下:

<pre name="code" class="html"><?xml version="1.0" encoding="utf-8"?>
<persons>
  <person id="001">
   <name>fnhfire7030</name>
   <age>21</age>
  </person>
  <person id="002">
   <name>fnhfire7030</name>
   <age>23</age>
  </person>
</persons>

然后我们就要建立一个解析器来解析XML文件,这里我们命名为PullXMLTools.java,具体内容如以下代码:

<pre name="code" class="java">package com.study.xiaohui.myapplication.parse;
import org.xmlpull.v1.XmlPullParser;
import org.xmlpull.v1.XmlPullParserException;
import org.xmlpull.v1.XmlPullParserFactory;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;
/**
 * Created by xiaohui on 2016/3/2.
 * 建立一个解析XML文件的类
 */
public class PullXMLTools {
    public List<PullXMLInfo> parseXML(InputStream inputStream, String encode) throws XmlPullParserException, IOException {
        List<PullXMLInfo> list = null;
        PullXMLInfo pullXMLInfo = null;
        //建立解析工厂
        XmlPullParserFactory factory = XmlPullParserFactory.newInstance();
        //获得XML文件的引用
        XmlPullParser pullParser = factory.newPullParser();
        //从服务器下载XML文件,以流的形式返回,设定解析XML文件的编码格式
        pullParser.setInput(inputStream, encode);
        int eventType = pullParser.getEventType();
        //对XML文件进行解析
        while (eventType != XmlPullParser.END_DOCUMENT) {
            switch (eventType) {
                case XmlPullParser.START_DOCUMENT:
                    list = new ArrayList<PullXMLInfo>();
                    break;
                case XmlPullParser.START_TAG:
                    if ("person".equals(pullParser.getName())) {
                        pullXMLInfo = new PullXMLInfo();
                        int id = Integer.parseInt(pullParser.getAttributeValue(0));
                        pullXMLInfo.setId(id);
                    } else if ("name".equals(pullParser.getName())) {
                        String name = pullParser.nextText();
                        pullXMLInfo.setName(name);
                    } else if ("age".equals(pullParser.getName())) {
                        int age = Integer.parseInt(pullParser.nextText());
                        pullXMLInfo.setAge(age);
                    }
                    break;
                case XmlPullParser.END_TAG:
                    if ("person".equals(pullParser.getName())) {
                        list.add(pullXMLInfo);
                        pullXMLInfo = null;
                    }
                    break;
            }
            eventType = pullParser.next();
        }
        return list;
    }
}

当然解析时,我们要定义一个实体类方便解析,我把实体类命名为PullXMLInfo.java,内容如下:

<span style="font-size:18px;">package com.study.xiaohui.myapplication.parse;
/**
 * Created by xiaohui on 2016/3/2.
 */
public class PullXMLInfo {
    public int id = 0;
    public String name = null;
    public int age = 0;
    public PullXMLInfo(int id, String name, int age) {
        this.id = id;
        this.name = name;
        this.age = age;
    }
    public PullXMLInfo() {
    }
    @Override
    public String toString() {
        return "PullXMLInfo{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", age=" + age +
                '}';
    }
    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;
    }
}
</span>

 因为我的XML文件是在我的tomcat中,因此需要写一个下载XML文件的方法,这里我自己重新定义了一个Downloader的类,里面的内容如下:

package com.study.xiaohui.myapplication.downloader;
import java.io.IOException;
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
/**
 * Created by xiaohui on 2016/3/2.
 * 从本机下载XML文件
 */
public class DownLoader {
    private URL url = null;
    public InputStream downloader(String str) {
        InputStream inputStream = null;
        try {
            url = new URL(str);
            HttpURLConnection connection = (HttpURLConnection) url.openConnection();
            //设置连接超时的时间
            connection.setConnectTimeout(3000);
            connection.setDoInput(true);
            connection.setRequestMethod("GET");
            //获取网络返回的状态码
            int responseCode = connection.getResponseCode();
            if (responseCode == 200) {
                inputStream = connection.getInputStream();
            }
        } catch (MalformedURLException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
        return inputStream;
    }
}

上面就是下载和解析XML文件的所有代码,我已经全部贴出,最后就是在Activity中调用了,好像从Android4.0开始就不能直接在主线程中下载文了,因此我继承了AsyncTask这个类。在这里就把代码全部贴出了吧!

package com.study.xiaohui.myapplication;
import android.os.AsyncTask;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import com.study.xiaohui.myapplication.downloader.DownLoader;
import com.study.xiaohui.myapplication.parse.PullXMLInfo;
import com.study.xiaohui.myapplication.parse.PullXMLTools;
import org.xmlpull.v1.XmlPullParserException;
import java.io.IOException;
import java.io.InputStream;
import java.util.List;
public class MainActivity extends AppCompatActivity {
    //本机XML文件的位置
    private String PATH = "http://192.168.1.101:82/mp3/example.xml";
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        //调用LongTasks
        LongTasks longTasks = new LongTasks();
        longTasks.execute();
    }
    //主线程中不能直接同网络下载内容,因此重新定义了一个继承AsyncTask的类
    class LongTasks extends AsyncTask<String, Void, List> {
        String str = PATH;
        @Override
        protected List doInBackground(String... params) {
            //定义一个List
            List<PullXMLInfo> list = null;
            DownLoader downLoader = new DownLoader();
            PullXMLTools pullXMLTools = new PullXMLTools();
            InputStream inputStream = downLoader.downloader(str);
            try {
                list = pullXMLTools.parseXML(inputStream, "utf-8");
                //读取List中的内容通过Log显示出来
                for (PullXMLInfo pullXMLInfo : list) {
                    Log.i("fnhFire", "" + pullXMLInfo.toString());
                }
            } catch (XmlPullParserException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
            return null;
        }
        @Override
        protected void onPostExecute(List list) {
            super.onPostExecute(list);
        }
    }
}

到这里使用Pull解析XML文件的步骤就全部完成了。上面的代码全部是本人亲测通过的,希望能对大家的学习和工作有所帮助。下面是解析出来的内容,我们与XML文件的内容对照发现完全一致。

20160302182254799.png



相关文章
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
463 2
|
10月前
|
Android开发 开发者
Android自定义View之不得不知道的文件attrs.xml(自定义属性)
本文详细介绍了如何通过自定义 `attrs.xml` 文件实现 Android 自定义 View 的属性配置。以一个包含 TextView 和 ImageView 的 DemoView 为例,讲解了如何使用自定义属性动态改变文字内容和控制图片显示隐藏。同时,通过设置布尔值和点击事件,实现了图片状态的切换功能。代码中展示了如何在构造函数中解析自定义属性,并通过方法 `setSetting0n` 和 `setbackeguang` 实现功能逻辑的优化与封装。此示例帮助开发者更好地理解自定义 View 的开发流程与 attrs.xml 的实际应用。
280 2
Android自定义View之不得不知道的文件attrs.xml(自定义属性)
|
Java
Java“解析时到达文件末尾”解决
在Java编程中,“解析时到达文件末尾”通常指在读取或处理文件时提前遇到了文件结尾,导致程序无法继续读取所需数据。解决方法包括:确保文件路径正确,检查文件是否完整,使用正确的文件读取模式(如文本或二进制),以及确保读取位置正确。合理设置缓冲区大小和循环条件也能避免此类问题。
1346 2
|
人工智能 自然语言处理 Java
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
FastExcel 是一款基于 Java 的高性能 Excel 处理工具,专注于优化大规模数据处理,提供简洁易用的 API 和流式操作能力,支持从 EasyExcel 无缝迁移。
3462 65
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
|
SQL 关系型数据库 MySQL
数据库导入SQL文件:全面解析与操作指南
在数据库管理中,将SQL文件导入数据库是一个常见且重要的操作。无论是迁移数据、恢复备份,还是测试和开发环境搭建,掌握如何正确导入SQL文件都至关重要。本文将详细介绍数据库导入SQL文件的全过程,包括准备工作、操作步骤以及常见问题解决方案,旨在为数据库管理员和开发者提供全面的操作指南。一、准备工作在导
2084 0
|
12月前
|
XML JavaScript Android开发
【Android】网络技术知识总结之WebView,HttpURLConnection,OKHttp,XML的pull解析方式
本文总结了Android中几种常用的网络技术,包括WebView、HttpURLConnection、OKHttp和XML的Pull解析方式。每种技术都有其独特的特点和适用场景。理解并熟练运用这些技术,可以帮助开发者构建高效、可靠的网络应用程序。通过示例代码和详细解释,本文为开发者提供了实用的参考和指导。
453 15
|
Java API 数据处理
深潜数据海洋:Java文件读写全面解析与实战指南
通过本文的详细解析与实战示例,您可以系统地掌握Java中各种文件读写操作,从基本的读写到高效的NIO操作,再到文件复制、移动和删除。希望这些内容能够帮助您在实际项目中处理文件数据,提高开发效率和代码质量。
460 4
|
Serverless 对象存储 人工智能
智能文件解析:体验阿里云多模态信息提取解决方案
在当今数据驱动的时代,信息的获取和处理效率直接影响着企业决策的速度和质量。然而,面对日益多样化的文件格式(文本、图像、音频、视频),传统的处理方法显然已经无法满足需求。
499 4
智能文件解析:体验阿里云多模态信息提取解决方案
|
自然语言处理 数据处理 Python
python操作和解析ppt文件 | python小知识
本文将带你从零开始,了解PPT解析的工具、工作原理以及常用的基本操作,并提供具体的代码示例和必要的说明【10月更文挑战第4天】
3198 60
|
存储 机器学习/深度学习 数据可视化
解析exe文件
如何使用`objdump`工具解析exe文件,包括exe文件的组成、`objdump`的用法以及如何查看exe文件的节头信息和完整内容。
825 0
解析exe文件

推荐镜像

更多
  • DNS