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());
}
}
}
全文请访问:
人人编程
分享到:
相关推荐
android xml pull解析示例,自己mark下,备忘
Android 封装pull解析xml,可直接调用
使用Android自带的XML解析器PULL解析器简单的解析xml,并将内容显示在TestView上,代码简化过。
在Android中,使用SAX和PULL解析XML,本项目中以解析天气预报为例。 详情见博客:http://blog.csdn.net/yalin18/article/details/7437752
pull解析xml文件,和sax和dom一样 都可以脱离android单独使用,pull和sax的原理一样,不一样的地方是pull读取xml文件后调用方法返回的是数字, 读取到xml的声明返回数字0 START_DOCUMENT; 读取到xml的结束返回数字1 ...
Android网络编程之Pull解析XML文件~
在android平台下使用PULL解析XML源码。
在Android平台上基于Pull方式对XML文件进行解析
@Introduction:使用PULL方法进行XML解析 XML文件存放在SDcard根目录下;android1.6版本之前是在/sdcard/,之后是在/mnt/sdcard/ 当前测试用来运行的版本是android。4.2.2 最小支持的版本是android.2.2.0 文件...
Android ReadXmlByPull 使用Pull解析Xml文件.rar
实现pull方式解析xml文件,xml文件放置在assets文件夹,View绑定使用butterknife
pull解析xml文件
在android中使用pull解析xml文件
Android 生成和PULL解析xml,生成的例子和PULL解析的例子,很详细。。
XML解析有三种方式 1,DOM 通用性强,它会将XML文件的所有内容读取到内存中,然后使用DOM API遍历XML树、检索所需的数据;...Android自带的XML解析器,和SAX基本类似,也是事件驱动,不同的是PULL事件返回的是数值型
Android Pull解析xml文件.
Android中采用Pull解析器读取和生成xml内容案例...
本例使用多种方式获取本地XML文件,还有通过url获取XML文件,使用Android内置的PULL解析器对XML文件进行解析,例子是解析我国各个省市。 《Android解析XML文件》博文路径:...
android Pull XML文件解析 存取 代码程序
Android解析xml(3)---Pull解析