Java数据解析---PULL
安卓和JAVA解析xml文件的三种方式:
1、PULL解析
2、SAX解析
3、DOM解析
三者各有所长,依情况选择解析方式
1、PULL和SAX均采用流式解析,意味着只能从头读到底,无法像DOM解析一样随机访问xml文件中的任意一个节点
2、PULL和SAX占用更少的内存解析,更适用于安卓上的解析xml文件
3、DOM解析时将文件全部解析完,最后让用户任意取特定的信息
-------------------------------------------------------------------------------------------------------------------------------------------------------------------
下面学习PULL解析方式。(PULL方法的简洁性是它最大的优势)
1、解析本地xml文件
public class PullParser {
public List<Worker> pullParsers() throws XmlPullParserException, IOException
{
List<Worker> list = null;
Worker worker = null;
//第一步:创建XML解析对象,需要通过工厂模式创建类的实例
XmlPullParserFactory factory = XmlPullParserFactory.newInstance();
XmlPullParser parser = factory.newPullParser();
// 第二步:设置待解析的xml数据源
FileInputStream fis = new FileInputStream("worker.xml");
parser.setInput(fis,"utf-8");
// 第三步:获取当前xml标签的事件类型
int event = parser.getEventType();
// 第四步:通过分支语句处理不同的事件标签
while(event!=XmlPullParser.END_DOCUMENT)
{
switch(event)
{
// 第五步:获取标签名称,处理标签信息
case XmlPullParser.START_DOCUMENT://解析文件开始,创建列表集合对象
list = new ArrayList<Worker>();
break;
case XmlPullParser.START_TAG:
String tagName = parser.getName();
if("worker".equals(tagName))
{
worker = new Worker();
int count = parser.getAttributeCount();//得到属性的个数
for(int i=;i<count;i++)
{
String attrName = parser.getAttributeName(i);
String attrValue = parser.getAttributeValue(i);
if("id".equals(attrName))
worker.setId(attrValue);
}
}
else if("name".equals(tagName))
worker.setName(parser.nextText());
worker.setMoney(Double.parseDouble(parser.nextText()));
break;
case XmlPullParser.END_TAG://解析文件结束,
if("worker".equals(parser.getName()))
{
// 第六步:将处理的数据保存到JavaBean或Map对象中
list.add(worker);
worker = null;
}
break;
}
// 第七步:获取下一个标签的事件类型,判断事件类型是否为文档结束事件,如果是则退出,反之重复第四、五、六步
event = parser.next();
}
return list;
}
/**
60 * @param args
61 * @throws IOException
62 * @throws XmlPullParserException
63 */
public static void main(String[] args) throws XmlPullParserException, IOException {
PullParser pullParser = new PullParser();
List<Worker> list = pullParser.pullParsers();
for(Worker w:list)
{
System.out.println(w);
}
}
}
Demo
<?xml version="1.0" encoding="UTF-8"?>
<workers>
<worker id="AQ01">
<name>Mark</name>
</worker>
<worker id="AD02">
<name>Luch</name>
</worker>
<worker id="AD03">
<name>Lily</name>
</worker>
<worker id="AD04">
<name>Lily</name>
</worker>
</workers>
xml文件
package com.qianfeng.pullparser2;
public class Worker {
private String id;
private String name;
public Worker() {
super();
// TODO Auto-generated constructor stub
}
public Worker(String id, String name) {
super();
this.id = id;
this.name = name;
}
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return "Worker [id=" + id + ", name=" + name + "]";
}
}
Worker.class 对象类
解析效果:
Worker [id=AQ01, name=Mark]
Worker [id=AD02, name=Luch]
Worker [id=AD03, name=Lily]
Worker [id=AD04, name=Lily]
控制台信息
2、解析服务器的xml文件
package pull; import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List; import org.xmlpull.v1.XmlPullParser;
import org.xmlpull.v1.XmlPullParserException;
import org.xmlpull.v1.XmlPullParserFactory; public class Pull { /**
* @param args
* @throws XmlPullParserException
* @throws IOException
*/
public static void main(String[] args) throws XmlPullParserException, IOException {
// TODO Auto-generated method stub
List<Person> list = null;
Person person=null; XmlPullParserFactory factory = XmlPullParserFactory.newInstance();
XmlPullParser parser = factory.newPullParser();
String path ="http://localhost:8080/aaa/person.xml";
InputStream in = HttpUtil.getInputStream(path);
parser.setInput(in, "utf-8");
int event = parser.getEventType();
while(event!=XmlPullParser.END_DOCUMENT)
{
switch(event)
{
case XmlPullParser.START_DOCUMENT:
System.out.println("文件解析开始");
list = new ArrayList<Person>();
break;
case XmlPullParser.START_TAG:
String str = parser.getName();
if("person".equals(str))
{
person = new Person();
int count = parser.getAttributeCount();
for(int i=;i<count;i++)
{
String key = parser.getAttributeName(i);
String value = parser.getAttributeValue(i);
if("id".equals(key))
{
person.setName(value);
}
}
}
else if("name".equals(str))
{
person.setName(parser.nextText());
}
break;
case XmlPullParser.END_TAG:
if("person".equals(parser.getName()))
{
list.add(person);
person=null;
}
break;
}
event = parser.next(); } for(int i=;i<list.size();i++)
{
System.out.println(list);
} } }
对应的HttpUtil自定义类getInpustStream方法
package pull; import java.io.IOException;
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL; public class HttpUtil {
public static InputStream getInputStream(String path) throws IOException{
URL url = new URL(path);
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setRequestMethod("GET");
conn.setConnectTimeout();
conn.setDoInput(true);
if(conn.getResponseCode() ==)
{
InputStream in = conn.getInputStream();
return in;
} return null; } }
HttpHtil.java
解析效果:
文件解析开始
[Pserson [id=, name=张老师, age=], Pserson [id=, name=李老师, age=]]
[Pserson [id=, name=张老师, age=], Pserson [id=, name=李老师, age=]]
控制台信息
Java数据解析---PULL的更多相关文章
- Java数据解析---JSON
一.Java数据解析分为:XML解析和JSON解析 XML解析即是对XML文件中的数据解析,而JSON解析即对规定形式的数据解析,比XML解析更加方便 JSON解析基于两种结构: 1.键值对类型 { ...
- Java数据解析之JSON
文章大纲 一.JSON介绍二.常见框架介绍与实战三.Studio中GsonFormat插件使用四.项目源码下载(含参考资料)五.参考文档 一.JSON介绍 1. 简介 JSON 的全称是 Ja ...
- Java数据解析之XML
文章大纲 一.XML解析介绍二.Java中XML解析介绍三.XML解析实战四.项目源码下载 一.XML解析介绍 最基础的XML解析方式有DOM和SAX,DOM和SAX是与平台无关的官方解析方式 ...
- Java数据解析---SAX
一.Sax解析 是从头到尾逐行逐个元素读取内容,修改较为不便,但适用于只读的大文档. Sax采用事件驱动的方式解析文档.简单点说,如同在电影院看电影一样,从头到尾看一遍就完了,不能回退(Dom可来来回 ...
- json-lib-2.4-jdk15.jar所需全部JAR包.rar java jsoup解析开彩网api接口json数据实例
json-lib-2.4-jdk15.jar所需全部JAR包.rar java jsoup解析开彩网api接口json数据实例 json-lib-2.4-jdk15.jar所需全部JAR包.rar ...
- 暚光科技定位系统数据解析-java
暚光科技定位系统数据解析-java package com.ygkj.test; import java.io.DataInputStream; import java.io.IOException; ...
- android基础(五)网络数据解析方法
在网络上传输数据时最常用的方法有两种:XML和JSON,下面就对这两种类型的数据解析进行讲解. 一.XML数据解析 在Android中,常见的XML解析器分别为SAX解析器.DOM解析器和PULL解析 ...
- Android网络之数据解析----SAX方式解析XML数据
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/ ...
- 网络相关系列之四:数据解析之SAX方式解析XML数据
一.XML和Json数据的引入: 通常情况下.每一个须要訪问网络的应用程序都会有一个自己的server.我们能够向server提交数据,也能够从server获取数据.只是这个时候就有一个问题,这些数据 ...
随机推荐
- Java匹马行天下——开篇
个人感言: 匹马行天下是我高中时候看过一部叫<九鼎记>的小说中的其中一个大章节标题,在整个这一章中,讲的是是主人公滕青山历经艰险,又心如磐石,一心修行,最后巅峰归来的故事.现在回想,依旧心 ...
- 可变码率(英语:Variable bitrate,简称VBR)介绍
可变码率(英语:Variable bitrate,简称VBR)这是一个用来形容通信服务质量(QoS for Quality of Service)的术语.和该词相对应的词是固定码率或固定比特率,英文c ...
- 来了!阿里开源分布式事务解决方案 Fescar
摘要: 阿里妹导读:广为人知的阿里分布式事务解决方案:GTS(Global Transaction Service),已正式推出开源版本,取名为“Fescar”,希望帮助业界解决微服务架构下的分布式事 ...
- 为什么我们喜欢用 sigmoid 这类 S 型非线性变换?
本文整理自 @老师木 的一条图片新浪微博,从另一个角度给出为何采用 sigmoid 函数作非线性变换的解释. 为什么我们喜欢用 sigmoid 这类 S 型非线性变换?
- jenkins内部分享ppt
持续集成Continuous integration简介(持续集成是什么) .持续集成源于极限编程(XP),是一种软件实践,软件开发过程中集成步骤是一个漫长并且无法预测的过程.集成过程中可能会爆 ...
- 高可用Hadoop平台-应用JAR部署
1.概述 今天在观察集群时,发现NN节点的负载过高,虽然对NN节点的资源进行了调整,同时对NN节点上的应用程序进行重新打包调整,负载问题暂时得到缓解.但是,我想了想,这样也不是长久之计.通过这个问题, ...
- SpringBoot全局配置文件
SpringBoot项目使用一个全局的配置文件application.properties或者是application.yml,在resources目录下或者类路径下的/config下,一般我们放到r ...
- Semaphore 与ThreadPoolExecutor 的使用
1. Semaphore 信号量 (阻塞) 优点:可以控制线程的数量,不会超出线程范围 缺点:当线程死锁时,永远没法释放,导致一直阻塞 在java中,提供了信号量Semaphore的支持. Sema ...
- springboot + freemarker 实现国际化
前言 写过一篇springboot+freemarker国际化过程中的细节问题,但没有写过具体的国际化实现过程.正好有人在问,我就把我实现的过程贴出来,即使自己知识的一个备份,如果对别人有点用,那是再 ...
- mybatis教程6(逆向工程)
什么是逆向工程 简单点说,就是通过数据库中的单表,自动生成java代码. Mybatis官方提供了逆向工程,可以针对单表自动生成mybatis代码(mapper.java\mapper.xml\po类 ...