我自己常用的xml解析

package com.leequer.Service;

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


import org.xmlpull.v1.XmlPullParser;

import android.util.Xml;

import com.leequer.Doem.Person;
/**
 * 使用pull解析xml
 *
 */
public class ReadXmlByPullService {
	
	public static List<Person> ReadXmlByPull (InputStream inputStream)throws Exception
	{
		List <Person> personList = null;
		/**
		 * android给我们提供了xml 用来得到xmlpull解析器
		 */
		XmlPullParser xmlpull = Xml.newPullParser();
		/**
		 * 将输入流传入 设定编码方式
		 * 
		 */
		xmlpull.setInput(inputStream, "utf-8");
		/**
		 * pull读到xml后 返回数字
		 *     读取到xml的声明返回数字0 START_DOCUMENT;
			   读取到xml的结束返回数字1 END_DOCUMENT ;
			   读取到xml的开始标签返回数字2 START_TAG
			   读取到xml的结束标签返回数字3 END_TAG
			   读取到xml的文本返回数字4 TEXT
		 */
		int eventCode = xmlpull.getEventType();
		/**
		 * 只要这个事件返回的不是1 我们就一直读取xml文件
		 */
		Person person = null;
		while(eventCode!=XmlPullParser.END_DOCUMENT)
		{
			
			switch (eventCode)
			{
				case XmlPullParser.START_DOCUMENT:
				{//开始文档 new数组
					personList =new  ArrayList<Person>();
					break;
				}
				case XmlPullParser.START_TAG:
				{
					if("person".equals(xmlpull.getName()))
					{
						person =  new Person();
						person.setId(xmlpull.getAttributeValue(0));
					}else if (person!=null)
					{
						if(("name".equals(xmlpull.getName())))
						{
							/**
							 * 如果当前元素的下一个元素是文本节点 就可以直接用nextText()这个方法来得到文本节点的内容
							 */
							person.setName(xmlpull.nextText());
						}else if ("age".equals(xmlpull.getName()))
						{
							/**
							 * 如果当前元素的下一个元素是文本节点 就可以直接用nextText()这个方法来得到文本节点的内容
							 */
							person.setAge(xmlpull.nextText());
						}
					}
					break;
				}
					
				case XmlPullParser.END_TAG:
				{ 
					if("person".equals(xmlpull.getName())&&person!=null)
					{
						personList.add(person);
						person = null;
					}
					break;
				}
			}
			
			eventCode = xmlpull.next();//没有结束xml文件就推到下个进行解析
			
			
		}
		
		return personList;
	}
}

你可能感兴趣的:(xml解析)