android解析xml比较麻烦,针对每个xml文件,需要有专门的xml解析类。
现对pull进行了简单的封装,不用再给每个xml创建解析类,可以直接解析xml。
能解析的xml形式主要有如下几种,其他复杂格式暂未支持。
1、支持简单的列表解析
2、支持简单的对象解析
3、支持对象中包含List列表的解析
主要代码如下:
package com.juziku.demo.xml;
import java.io.InputStream;
import java.lang.reflect.Field;
import java.lang.reflect.ParameterizedType;
import java.lang.reflect.Type;
import java.util.ArrayList;
import java.util.List;
import org.xmlpull.v1.XmlPullParser;
import android.util.Log;
import android.util.Xml;
/**
* 对pull解析xml进行了封装,不用给每个xml,再创建一个解析类
*
* @author steven
*
* http://www.juziku.com/sunlightcs/
*
*/
public class XmlParse {
/**
* 解析XML
* @param is xml字节流
* @param clazz 字节码 如:Object.class
* @param startName 开始位置
* @return 返回List列表
*/
@SuppressWarnings({ "rawtypes", "unchecked" })
public List getXmlList(InputStream is, Class<?> clazz, String startName) {
List list = null;
XmlPullParser parser = Xml.newPullParser();
Object object = null;
try {
parser.setInput(is, "UTF-8");
//事件类型
int eventType = parser.getEventType();
while (eventType != XmlPullParser.END_DOCUMENT) {
switch (eventType) {
case XmlPullParser.START_DOCUMENT:
list = new ArrayList<Object>();
break;
case XmlPullParser.START_TAG:
//获得当前节点元素的名称
String name = parser.getName();
if (startName.equals(name)) {
object = clazz.newInstance();
//判断标签里是否有属性,如果有,则全部解析出来
int count = parser.getAttributeCount();
for(int i=0; i<count; i++)
setXmlValue(object, parser.getAttributeName(i), parser.getAttributeValue(i));
} else if (object != null) {
setXmlValue(object, name, parser.nextText());
}
break;
case XmlPullParser.END_TAG:
if (startName.equals(parser.getName())) {
list.add(object);
object = null;
}
break;
}
eventType = parser.next();
}
} catch (Exception e) {
Log.e("xml pull error", e.toString());
}
return list;
}
/**
* 解析XML
* @param is xml字节流
* @param clazz 字节码 如:Object.class
* @return 返回Object
*/
@SuppressWarnings({ "unchecked", "rawtypes" })
public Object getXmlObject(InputStream is, Class<?> clazz) {
XmlPullParser parser = Xml.newPullParser();
Object object = null;
List list = null;
Object subObject = null;
String subName = null;
try {
parser.setInput(is, "UTF-8");
//事件类型
int eventType = parser.getEventType();
while (eventType != XmlPullParser.END_DOCUMENT) {
switch (eventType) {
case XmlPullParser.START_DOCUMENT:
object = clazz.newInstance();
break;
case XmlPullParser.START_TAG:
//获得当前节点元素的名称
String name = parser.getName();
Field[] f = null;
if(subObject == null){
f = object.getClass().getDeclaredFields();
//判断标签里是否有属性,如果有,则全部解析出来
int count = parser.getAttributeCount();
for(int j=0; j<count; j++)
setXmlValue(object, parser.getAttributeName(j), parser.getAttributeValue(j));
}else{
f = subObject.getClass().getDeclaredFields();
}
for(int i = 0; i < f.length; i++){
if(f[i].getName().equalsIgnoreCase(name)){
//判断是不是List类型
if(f[i].getType().getName().equals("java.util.List")){
Type type = f[i].getGenericType();
if (type instanceof ParameterizedType) {
//获得泛型参数的实际类型
Class<?> subClazz = (Class<?>)((ParameterizedType)type).getActualTypeArguments()[0];
subObject = subClazz.newInstance();
subName = f[i].getName();
//判断标签里是否有属性,如果有,则全部解析出来
int count = parser.getAttributeCount();
for(int j=0; j<count; j++)
setXmlValue(subObject, parser.getAttributeName(j), parser.getAttributeValue(j));
if(list == null){
list = new ArrayList<Object>();
f[i].setAccessible(true);
f[i].set(object, list);
}
}
}else{ //普通属性
if(subObject != null){
setXmlValue(subObject, name, parser.nextText());
}else{
setXmlValue(object, name, parser.nextText());
}
}
break;
}
}
break;
case XmlPullParser.END_TAG:
if (subObject != null && subName.equalsIgnoreCase(parser.getName())) {
list.add(subObject);
subObject = null;
subName = null;
}
break;
}
eventType = parser.next();
}
} catch (Exception e) {
Log.e("xml pull error", e.getMessage());
}
return object;
}
/**
* 把xml标签的值,转换成对象里属性的值
* @param t 对象
* @param name xml标签名
* @param value xml标签名对应的值
*/
private void setXmlValue(Object t, String name, String value){
try {
Field[] f = t.getClass().getDeclaredFields();
for(int i = 0; i < f.length; i++){
if(f[i].getName().equalsIgnoreCase(name)){
f[i].setAccessible(true);
//获得属性类型
Class<?> fieldType = f[i].getType();
if(fieldType == String.class) {
f[i].set(t, value);
}else if(fieldType == Integer.TYPE) {
f[i].set(t, Integer.parseInt(value));
}else if(fieldType == Float.TYPE) {
f[i].set(t, Float.parseFloat(value));
}else if(fieldType == Double.TYPE) {
f[i].set(t, Double.parseDouble(value));
}else if(fieldType == Long.TYPE) {
f[i].set(t, Long.parseLong(value));
}else if(fieldType == Short.TYPE) {
f[i].set(t, Short.parseShort(value));
}else if(fieldType == Boolean.TYPE) {
f[i].set(t, Boolean.parseBoolean(value));
}else{
f[i].set(t, value);
}
}
}
} catch (Exception e) {
Log.e("xml error", e.toString());
}
}
}
全文请访问:
人人编程
分享到:
相关推荐
XML Pull解析器是基于事件驱动的解析方式,它会触发一系列事件(如开始标签、结束标签、文本数据等),开发者可以注册监听这些事件,从而实现对XML文档的解析。这种方式既节省内存又提高效率,特别适合处理大型XML...
本篇文章将详细介绍如何在Android中封装一个基于Pull解析的XML处理工具,并演示如何直接调用这个工具进行XML解析。 Android支持两种主要的XML解析方式:DOM(Document Object Model)解析和SAX(Simple API for XML...
本文将深入探讨如何在Android中使用两种常见的XML解析技术——SAX(Simple API for XML)和PULL(Pull Parser)来解析天气预报的XML数据。这两种方法各有优缺点,适用于不同的场景。 首先,我们来看SAX解析器。SAX...
Android系统提供了一种轻量级的XML解析方式——PULL解析器(Pull Parser),它适用于处理大型XML文档,因为它不需要像DOM解析器那样一次性加载整个XML文档到内存中。PULL解析器通过事件驱动的方式,按需解析XML文档...
在Android项目中,首先需要添加对`androidx.xml`库的依赖,确保解析器可用。在`build.gradle`文件中添加以下依赖: ```gradle dependencies { implementation 'androidx.xml:xml:1.0.0' } ``` 2. **创建Pull...
本文将深入探讨如何在Android中使用PULL解析器(Pull Parser)来解析XML文档,这是一种轻量级且高效的解析方式。 **PULL解析器概述** PULL解析器(Pull Parsing)是一种事件驱动的解析模型,它不需要完整的XML文档...
pull解析xml文件,和sax和dom一样 都可以脱离android单独使用,pull和sax的原理一样,不一样的地方是pull读取xml文件后调用方法返回的是数字, 读取到xml的声明返回数字0 START_DOCUMENT; 读取到xml的结束返回数字1 ...
7. **应用场景**:Android系统配置、网络API响应、XML配置文件等都可能涉及XML Pull解析。 总之,Android的XML Pull解析器是一个轻量级且高效的工具,适用于处理XML数据。通过理解其基本原理和操作方法,开发者可以...
总结,本教程介绍了如何在Android中使用PULL解析XML,以及如何结合ButterKnife进行视图绑定。PULL解析提供了高效且内存友好的方式处理XML数据,而ButterKnife则简化了UI组件的管理,两者结合能有效提升开发效率。...
本文将深入探讨Android中的Pull解析XML技术,以及如何利用模板快速实现XML的解析。 首先,理解XML Pull解析器的工作原理是至关重要的。在Android中,XML Pull解析是一种轻量级处理XML文档的方式,它允许应用移动...
本教程将详细介绍如何在Android中利用Pull解析器(PullParser)来读取XML文件,这是一种高效且内存友好的方式。 首先,让我们了解什么是Pull解析器。Pull解析器是一种事件驱动的解析模型,它不创建整个XML文档树,...
本文将深入探讨如何在Android中使用Pull解析器解析XML文件。 一、XML Pull解析器简介 XML Pull解析器(XML Pull API)是一种基于事件驱动的解析模型,它不需预先加载整个XML文档,而是逐行读取,当遇到特定的XML...
@Introduction:使用PULL方法进行XML解析 XML文件存放在SDcard根目录下;android1.6版本之前是在/sdcard/,之后是在/mnt/sdcard/ 当前测试用来运行的版本是android。4.2.2 最小支持的版本是android.2.2.0 文件...
本文将深入探讨如何在Android中生成XML文件以及如何使用PULL解析器来解析XML数据。 首先,我们来看一下如何在Android中生成XML文件。生成XML文件通常涉及创建一个XMLWriter对象,然后通过调用其方法来添加元素、...
XML Pull解析的核心思想是:解析器向解析者(即应用程序)推送解析事件,如开始标签、结束标签、文本内容等,解析者根据这些事件进行相应的处理。这种方式简化了XML解析的流程,使得解析XML的过程更加可控。 描述中...
在Android开发中,"13pull解析xml天气信息"是一个典型的任务,涉及到网络数据获取、XML解析以及用户界面展示等多个方面。在这个例子中,开发者通常会利用Android的Pull解析器来处理XML数据,从而获取并显示天气预报...
在Android系统中,XML解析主要有两种方式:DOM解析和PULL解析。本文将深入探讨Android中的XML Pull解析,包括基本概念、使用方法以及本地和网络XML数据的处理。 一、XML Pull解析基础 XML Pull解析是一种事件驱动...
总之,Android提供了SAX和PULL两种解析XML的手段,开发者可以根据具体情况灵活选择。在内存有限或者需要高效处理大量XML数据的情况下,SAX可能是更好的选择;而在追求简洁代码和快速开发的场合,PULL解析则更为便捷...
Android系统提供了三种主要的XML解析方式:DOM(Document Object Model)、PULL(Pull Parser)和SAX(Simple API for XML)。每种方法都有其独特的特性和应用场景,下面将详细介绍这三种XML解析方式。 1. DOM解析...
在Android应用中,我们通常使用两种方式来解析XML:DOM(Document Object Model)解析器和SAX(Simple API for XML)解析器。 1. DOM解析: DOM解析器将整个XML文件加载到内存中,形成一个树形结构,可以方便地遍历...