使用pull方式解析xml文件

原创 2015年11月19日 17:16:15
<?xml version='1.0' encoding='utf-8' standalone='yes' ?>
<weather>
	<city>
		<name>上海</name>
		<temp>5°</temp>
		<pm>80</pm>
	</city>
	<city>
		<name>北京</name>
		<temp>-5°</temp>
		<pm>800</pm>
	</city>
	<city>
		<name>西安</name>
		<temp>12°</temp>
		<pm>60</pm>
	</city>
</weather>



public class MainActivity extends Activity {

	List<City> cityList;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
	}

	public void click(View v){
		//获取到src文件夹下的资源文件
		InputStream is = getClassLoader().getResourceAsStream("weather.xml");
		
		//拿到pull解析器对象
		XmlPullParser xp = Xml.newPullParser();
		//初始化
		try {
			xp.setInput(is, "gbk");
			
			//获取当前节点的事件类型,通过事件类型的判断,我们可以知道当前节点是什么节点,从而确定我们应该做什么操作
			int type = xp.getEventType();
			City city = null;
			while(type != XmlPullParser.END_DOCUMENT){
				//根据节点的类型,要做不同的操作
				switch (type) {
				case XmlPullParser.START_TAG:
					//					获取当前节点的名字
					if("weather".equals(xp.getName())){
						//创建city集合对象,用于存放city的javabean
						cityList = new ArrayList<City>();
					}
					else if("city".equals(xp.getName())){
						//创建city的javabean对象
						city = new City();
					}
					else if("name".equals(xp.getName())){
						//				获取当前节点的下一个节点的文本
						String name = xp.nextText();
						city.setName(name);
					}
					else if("temp".equals(xp.getName())){
						//				获取当前节点的下一个节点的文本
						String temp = xp.nextText();
						city.setTemp(temp);
					}
					else if("pm".equals(xp.getName())){
						//				获取当前节点的下一个节点的文本
						String pm = xp.nextText();
						city.setPm(pm);
					}
					break;
				case XmlPullParser.END_TAG:
					if("city".equals(xp.getName())){
						//把city的javabean放入集合中
						cityList.add(city);
					}
					break;

				}
				
				//把指针移动到下一个节点,并返回该节点的事件类型
				type = xp.next();
			}
			
			for (City c : cityList) {
				System.out.println(c.toString());
			}
		} catch (Exception e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}

}


使用Jdom解析XML

关于使用jdom解析xml
  • u011526599
  • u011526599
  • 2016年10月23日 17:27
  • 1750

java中用SAX解析XML

原文地址:http://www.cnblogs.com/allenzheng/archive/2012/12/01/2797196.html 注:考虑到自己程序中表结构比较大,有几百个字段,再加...
  • w2393040183
  • w2393040183
  • 2016年07月15日 11:11
  • 1675

Android解析XML方式(二)使用PULL解析XML

在前一篇中介绍了使用SAX解析XML,本篇来讲一下如何使用JAVA自带的PULL来解析XML数据,以及它们的各自优点在哪里。 首先来看一下什么是PULL解析器以及它的基本特征: PULL解析器的运...
  • wulianghuan
  • wulianghuan
  • 2013年02月26日 21:23
  • 4266

Gson解析(详解)

先介绍一下Android原生的解析 在Android中包含四个与JSON相关的类和一个Exceptions: JSONObject    JSONArray             J...
  • heinika
  • heinika
  • 2015年11月08日 16:56
  • 2772

IOS学习:常用第三方库(GDataXMLNode:xml解析库)

一、GDataXMLNode说明 GDataXMLNode是Google提供的用于XML数据处理的类集。该类集对libxml2--DOM处理方式进行了封装,能对较小或中等的xml文档进行读写...
  • wu_shu_jun
  • wu_shu_jun
  • 2013年05月30日 09:45
  • 25885

SwiftyJSON之使用分析

SwiftYJSON
  • watertekhqx
  • watertekhqx
  • 2017年03月07日 09:17
  • 574

对Oracle软软解析的一点看法

摘要: 本文将介绍Oracle解析器的一种较为特殊的解析行为,软软解析。 杂谈  在接触过oracle优化器的特征之后,我们都知道oracle优化器的一个迷人之处,就在于share...
  • qq_40954115
  • qq_40954115
  • 2017年11月13日 14:53
  • 65

使用 Beautiful Soup 解析网页内容

安装Beautiful SoupBeautiful Soup是一个Python的HTML解析框架,我们可以利用它方便的处理HTML和XML文档。Beautiful Soup有3和4两个版本,目前3已经...
  • u011054333
  • u011054333
  • 2017年04月03日 21:34
  • 1391

java使用dcm4che3 解析dicom文件

先说一下背景吧,有一台眼底照相机,拍摄患者的眼底信息后发送dicom文件到指定的服务器上面,然后再解析dicom文件,获取其中的图片和患者的其他信息,入库 给医生筛查。在gitHub上面找了一个监听指...
  • gyhcsdn1995
  • gyhcsdn1995
  • 2017年04月05日 11:01
  • 2597

jsoup解析的常见用法

1、解析attribute中值,如下面所示的serviceID和serviceName: String str="如下所示"; 解析方法:  List> resultList = ne...
  • u014034854
  • u014034854
  • 2015年07月16日 12:12
  • 1126
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:使用pull方式解析xml文件
举报原因:
原因补充:

(最多只允许输入30个字)