xml文件解析(使用解析器)
一.Xml解析,解析xml并封装到list中的javabean中
OM是用与平台和语言无关的方式表示XML文档的官方W3C标准。DOM是以层次结构组织的节点或信息片断的集合。这个层次结构允许开发人员在树中寻找特定信息。分析该结构通常需要加载整个文档和构造层次结构,然后才能做任何工作。由于它是基于信息层次的,因而DOM被认为是基于树或基于对象的。DOM以及广义的基于树的处理具有几个优点。首先,由于树在内存中是持久的,因此可以修改它以便应用程序能对数据和结构作出更改。它还可以在任何时候在树中上下导航,而不是像SAX那样是一次性的处理
1.获取xml解析器
XmlPullParser xpp = Xml.newPullParser();
2.设置解析器参数
xpp.setInput(in, "utf-8");//in为输入流
3.获取事件类型
int type = xpp.getEventType();
4.不断向下解析,一行一行解析
while(type != XmlPullParser.END_DOCUMENT){
switch(type){
case XmlPullParser.START_TAG://解析开始标签
//具体判断是哪个开始标签
if("weather".equals(xpp.getName())){
weatherlist = new ArrayList<Channel>();
}else if("channel".equals(xpp.getName())){
ch = new Channel();
String id = xpp.getAttributeValue(0);
ch.setId(id);
}else if("city".equals(xpp.getName())){
String city = xpp.nextText();
ch.setCity(city);
}else if("temp".equals(xpp.getName())){
String temp = xpp.nextText();
ch.setTemp(temp);
}else if("wind".equals(xpp.getName())){
String wind = xpp.nextText();
ch.setWind(wind);
}else if("pm2.5".equals(xpp.getName())){
String pm250 = xpp.nextText();
ch.setPm250(pm250);
}
break;
case XmlPullParser.END_TAG://解析结束标签
//判断要解析的结束标签
if("channel".equals(xpp.getName())){
//把ch对象添加到集合
weatherlist.add(ch);
}
break;
}
type = xpp.next();
}
5.对应的要解析的文件:
<?xml version="1.0" encoding="utf-8"?>
<weather>
<channel id="1">
<city>北京</city>
<temp>16℃</temp>
<wind>4</wind>
<pm2.5>300</pm2.5>
</channel> <channel id="2">
<city>上海</city>
<temp>20℃</temp>
<wind>5</wind>
<pm2.5>200</pm2.5>
</channel> <channel id="3">
<city>广州</city>
<temp>25℃</temp>
<wind>3</wind>
<pm2.5>100</pm2.5>
</channel> <channel id="4">
<city>深圳</city>
<temp>27℃</temp>
<wind>6</wind>
<pm2.5>150</pm2.5>
</channel> </weather>
6.对应的JAVABEAN代码
package com.hui.xmlparse; import java.io.InputStream;
import java.util.ArrayList;
import java.util.List; import org.xmlpull.v1.XmlPullParser; import android.util.Xml; public class ParserXml { public static List<Channel> weatherlist = null;
public static Channel ch = null; public static List <Channel> weatherParser(InputStream in) throws Exception {
//获取xml解析器
XmlPullParser xpp = Xml.newPullParser();
//设置解析器参数
xpp.setInput(in, "utf-8");
//获取事件类型
int type = xpp.getEventType();
//不断向下解析
while(type != XmlPullParser.END_DOCUMENT){
switch(type){ case XmlPullParser.START_TAG://解析开始标签
//具体判断是哪个开始标签
if("weather".equals(xpp.getName())){
weatherlist = new ArrayList<Channel>();
}else if("channel".equals(xpp.getName())){
ch = new Channel();
String id = xpp.getAttributeValue(0);
ch.setId(id);
}else if("city".equals(xpp.getName())){
String city = xpp.nextText();
ch.setCity(city);
}else if("temp".equals(xpp.getName())){
String temp = xpp.nextText();
ch.setTemp(temp);
}else if("wind".equals(xpp.getName())){
String wind = xpp.nextText();
ch.setWind(wind);
}else if("pm2.5".equals(xpp.getName())){
String pm250 = xpp.nextText();
ch.setPm250(pm250);
}
break;
case XmlPullParser.END_TAG://解析结束标签
//判断要解析的结束标签
if("channel".equals(xpp.getName())){
//把ch对象添加到集合
weatherlist.add(ch);
}
break; }
type = xpp.next();
} return weatherlist;
} }
xml文件解析(使用解析器)的更多相关文章
- 对xml文件的sax解析(增删改查)之一
crud(增删改查): c:creat r:retrieve u:update d:delete 以下笔记来自于韩顺平老师的讲解. 现在是用java来操作. 第一步:新建java工程.file-new ...
- Pugixml一种快速解析XML文件的开源解析库
Pugixml是一个轻量级的C++ XML开源解析库,DOM形式的解析器.接口和丰富的遍历和修改操作,快速的解析,此外支持XPath1.0实现数据查询,支持unicode编码: 使用Pugixml可通 ...
- 对xml文件的sax解析(增删改查)之二
先上代码: package com.saxparsetest; //the filename of this file is :saxparse.java import javax.xml.parse ...
- 2.3 使用 dom4j 对 xml文件进行 dom 解析
// 使用dom4j对XML文档进行解析 CRUD public class Demo1 { //读取XML文档中第二本书的书名 <书名>javaWEB</书名> @Test ...
- xml文件使用DOM解析,报异常org.xml.sax.SAXParseException,"characterEncoding" 的引用必须以 ';' 分隔符结尾异常
这个异常一般为xml文件对&的报错,只需要将&改为转义后的&即可解决
- 对xml文件的简单解析
package com.eprobj.demo; import java.io.IOException; import javax.xml.parsers.DocumentBuilder; impor ...
- 利用freemarker生成word,word另存为xml文件的标签解析
http://wenku.baidu.com/link?url=YxTZWVP3ssO-e_Br3LIZVq2xOQnqaSz8gLPiRUDN8NIR_wX2-Z25OqwbVn5kXqGiOFYU ...
- JAVA使用SAX解析XML文件
在我的另一篇文章(http://www.cnblogs.com/anivia/p/5849712.html)中,通过一个例子介绍了使用DOM来解析XML文件,那么本篇文章通过相同的XML文件介绍如何使 ...
- IOS的XML文件解析,利用了NSData和NSFileHandle
如果需要了解关于文档对象模型和XML的介绍,参看 http://www.cnblogs.com/xinchrome/p/4890723.html 读取XML 上代码: NSFileHandle *fi ...
- 使用SAX解析XML文件
SAX这是Simple API for XML缩写,它不是由引起W3C拟议标准正式.尽管如此,使用SAX很少几个,点儿全部的XML解析器都会支持它. 与DOM比較而言,SAX是一种轻量型的方法. 我们 ...
随机推荐
- 题目1083:特殊乘法-九度oj
题目描述: 写个算法,对2个小于1000000000的输入,求结果. 特殊乘法举例:123 * 45 = 1*4 +1*5 +2*4 +2*5 +3*4+3*5 输入: 两个小于1000000000的 ...
- poj 3070 && nyoj 148 矩阵快速幂
poj 3070 && nyoj 148 矩阵快速幂 题目链接 poj: http://poj.org/problem?id=3070 nyoj: http://acm.nyist.n ...
- HDU 1698 Just a Hook 线段树+lazy-target 区间刷新
Just a Hook Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tota ...
- CCF-201312-1-出现次数最多的数
问题描述 试题编号: 201312-1 试题名称: 出现次数最多的数 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 给定n个正整数,找出它们中出现次数最多的数.如果这样的数有 ...
- 前端页面适配的rem换算
为什么要使用rem 之前有些适配做法,是通过js动态计算viewport的缩放值(initial-scale). 例如以屏幕320像素为基准,设置1,那屏幕375像素就是375/320=1.18以此类 ...
- 游标遍历所有数据库循环执行修改数据库的sql命令
MSSQL数据库服务器上有很多类似的数据库,需要将这些数据库统一修改其中的某些表或者某些命令,那么就会想到用游标来遍历. 先来说思路: 1,首先需要查询出所有的数据库: select [name] f ...
- Netty之粘包分包
粘包现象 客户端在一个for循环内连续发送1000个hello给Netty服务器端, Socket socket = new Socket("127.0.0.1", 10101); ...
- object 覆盖 div 在IE 和Firefox 的解决方案
问题描述 公司产品需要在三维(3D)控件上显示弹框,按钮等,然而三维控件的object覆盖了div,弹框和按钮不能显示 firefox 解决方案 最外层div的背景使用不透明背景色,必须是不透明的哦 ...
- ArrayList在foreach正常迭代删除不报错的原因
一.背景 在以前的随笔中说道过ArrayList的foreach迭代删除的问题:ArrayList迭代过程删除问题 按照以前的说法,在ArrayList中通过foreach迭代删除会抛异常:java. ...
- JAVA基础-----Maven项目的搭建
Maven项目的搭建 一.前言 maven官网:http://maven.apache.org/, 文章简介:本文章从三个模块来了解Maven,分别是 Maven的基本概念~, Maven项目的安装和 ...