1. 创建XML文件对象及其序列化

示例代码:(模拟以xml格式备份短信到SD卡)

SmsInfo.java, bean对象

/**
* 短信的业务bean
* @author Administrator
*
*/
public class SmsInfo {
private String body;
private String number;
private int type;
private long id; public long getId() {
return id;
} public void setId(long id) {
this.id = id;
} public SmsInfo() {
} public SmsInfo(String body, String number, int type,long id) {
this.body = body;
this.number = number;
this.type = type;
this.id = id;
} public String getBody() {
return body;
} public void setBody(String body) {
this.body = body;
} public String getNumber() {
return number;
} public void setNumber(String number) {
this.number = number;
} public int getType() {
return type;
} public void setType(int type) {
this.type = type;
} }

SmsUtils.java 工具类

public class SmsUtils {

	/**
* 短信备份的工具方法
* @param file 短信备份到哪个文件里面
* @param smsInfos 要备份的短信对象的集合.
*/
public static void backUpSms(File file, List<SmsInfo> smsInfos) throws Exception{
//xml文件的序列号器 帮助生成一个xml文件
FileOutputStream fos = new FileOutputStream(file);
//1.获取到xml的序列号器
XmlSerializer serializer = Xml.newSerializer();
//2.序列化器的初始化
serializer.setOutput(fos, "utf-8"); //文件的编码方式 utf-8
//3.创建xml文件,编码和是否独立,如果独立,一个xml文件 就会包含所有信息
serializer.startDocument("utf-8", true);
serializer.startTag(null, "smss"); //循环的把所有的短信数据都写到 xml文件里面
for(SmsInfo info: smsInfos){
serializer.startTag(null, "sms");
serializer.attribute(null, "id", String.valueOf(info.getId())); serializer.startTag(null, "body");
serializer.text(info.getBody());
serializer.endTag(null, "body"); serializer.startTag(null, "type");
serializer.text(info.getType()+"");
serializer.endTag(null, "type"); serializer.startTag(null, "number");
serializer.text(info.getNumber());
serializer.endTag(null, "number"); serializer.endTag(null, "sms");
}
serializer.endTag(null, "smss");
serializer.endDocument(); fos.flush();
fos.close();
}
}

MainActivity.java

public class MainActivity extends Activity {

	@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); List<SmsInfo> smsInfos = new ArrayList<SmsInfo>(); //模拟创建两个短信数据的对象.
SmsInfo sms1 = new SmsInfo("你好啊 短信1", "5556", 1,9999);
SmsInfo sms2 = new SmsInfo("你好啊 短信2", "5558", 1,8888); smsInfos.add(sms1);
smsInfos.add(sms2); File file = new File(Environment.getExternalStorageDirectory(),"back.xml");
try {
SmsUtils.backUpSms(file, smsInfos);
Toast.makeText(this, "备份短信成功", 0).show();
} catch (Exception e) {
e.printStackTrace();
Toast.makeText(this, "备份短信失败", 0).show();
}
}
}

2. pull解析XML文件

示例代码:(模拟解析xml格式的天气情况)

weather.xml 需要解析的XML文件

<?xml version='1.0' encoding='utf-8' standalone='yes' ?>
<weather>
<day id="1">
<wendu>18</wendu>
<wind>5</wind>
<type>晴</type>
</day>
<day id="2">
<wendu>16</wendu>
<wind>3</wind>
<type>雨</type>
</day>
</weather>

Weather.java, bean

public class Weather {
private int wendu;
private int wind;
private String type;
private int id;
public int getWendu() {
return wendu;
}
public void setWendu(int wendu) {
this.wendu = wendu;
}
public int getWind() {
return wind;
}
public void setWind(int wind) {
this.wind = wind;
}
public String getType() {
return type;
}
public void setType(String type) {
this.type = type;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
@Override
public String toString() {
return "天气信息 [温度=" + wendu + ", 风力=" + wind + "级 , 天气状况=" + type
+ ", 未来第=" + id + "天]";
}
}

WeatherService.java,业务类

public class WeatherService {
/**
* 解析获取天气信息
*
* @param is
* 天气信息xml文件对应的流
* @return
* @throws Exception
*/
public static List<Weather> getWeather(InputStream is) throws Exception {
// 解析 天气的xml文件.
// 1.获取到一个xml文件的解析器.
XmlPullParser parser = Xml.newPullParser();
// 2.初始化解析器.
parser.setInput(is, "utf-8");
// 3.解析xml文件.
// 得到当前解析条目的节点类型.
int eventType = parser.getEventType(); // 第一次被调用的时候 定位在xml开头
List<Weather> weatherInfos = null;
Weather weatherInfo = null;
while (eventType != XmlPullParser.END_DOCUMENT) {// 需要 不停的让 解析器解析下一个节点
switch (eventType) {
case XmlPullParser.START_TAG:
if ("weather".equals(parser.getName())) {
// 发现开始节点 为weather 创建集合
weatherInfos = new ArrayList<Weather>();
} else if ("day".equals(parser.getName())) {
// 发现一个新的日期 对应的天气
weatherInfo = new Weather();
String id = parser.getAttributeValue(0);
weatherInfo.setId(Integer.parseInt(id));
} else if ("wendu".equals(parser.getName())) {
String wendu = parser.nextText();
weatherInfo.setWendu(Integer.parseInt(wendu));
} else if ("wind".equals(parser.getName())) {
String wind = parser.nextText();
weatherInfo.setWind(Integer.parseInt(wind));
} else if ("type".equals(parser.getName())) {
String type = parser.nextText();
weatherInfo.setType(type);
} break; case XmlPullParser.END_TAG:
if ("day".equals(parser.getName())) {
weatherInfos.add(weatherInfo);
}
break;
}
eventType = parser.next();// 控制解析器 解析下一个节点
}
is.close();
return weatherInfos; }
}

MainActivity.java

public class MainActivity extends Activity {

	@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); TextView tv = (TextView) findViewById(R.id.tv_weather); try {
StringBuilder sb = new StringBuilder();
List<Weather> weatherinfos = WeatherService.getWeather(getClassLoader().getResourceAsStream("weather.xml"));
for(Weather weather : weatherinfos){
sb.append(weather.toString());
sb.append("\n"); }
tv.setText(sb.toString()); } catch (Exception e) {
e.printStackTrace();
Toast.makeText(this, "解析天气信息失败", 0).show();
}
}
}

Android -- 创建XML文件对象及其序列化, pull解析XML文件的更多相关文章

  1. 使用XML序列化器生成XML文件和利用pull解析XML文件

    首先,指定XML格式,我指定的XML格式如下: <?xml version='1.0' encoding='utf-8' standalone='yes' ?> <message&g ...

  2. Android SAX、DOM、Pull解析xml文件剖析与案例讲解

    XML介绍 XML(Extensible Markup Language) 即可扩展标记语言,与HTML一样,都是SGML(Standard Generalized Markup Language,标 ...

  3. 使用PULL解析XML文件

    转载博文1:http://blog.csdn.net/wangkuifeng0118/article/details/7313241 XmlPull和Sax类似,是基于流(stream)操作文件,然后 ...

  4. Android之Pull解析XML

    一.Pull解析方法介绍 除了可以使用SAX和DOM解析XML文件,也可以使用Android内置的Pull解析器解析XML文件.Pull解析器的运行方式与SAX解析器相似.它也是事件触发的.Pull解 ...

  5. Android——PULL解析XML

    简介 Android中常常使用XML文件保存用户的APP设置信息.因此需要对XML文件的相关操作进行了解.本文将以<学生信息管理系统>为案例背景进行介绍相关的XML解析的介绍,以及其他相关 ...

  6. Android系列--DOM、SAX、Pull解析XML

    您可以通过点击 右下角 的按钮 来对文章内容作出评价, 也可以通过左下方的 关注按钮 来关注我的博客的最新动态. 如果文章内容对您有帮助, 不要忘记点击右下角的 推荐按钮 来支持一下哦 如果您对文章内 ...

  7. pull解析xml文件

    pull解析xml文件 先自己写一个xml文件,存一些天气信息 拿到xml文件 InputStream is = getClassLoader().getResourceAsStream(" ...

  8. PULL解析XML的运行机制详解

    PULL解析简单易上手,基本上看一遍,基本上就会解析啦,但总是感觉对PULL解析的运行机制不是很了解,就总结了以下事件驱动到底是怎么执行的.. PULL: Android内置了PULL解析器.PULL ...

  9. XListview的下拉刷新、上拉加载、用Pull解析XML

    做之前需要导入XListview的文件,此是用第三方的xListview实现的,东西没写全.此是在Fragment中实现的 //--------------XListView的布局---------- ...

随机推荐

  1. 【BZOJ4567】[Scoi2016]背单词 Trie树+贪心

    [BZOJ4567][Scoi2016]背单词 Description Lweb 面对如山的英语单词,陷入了深深的沉思,“我怎么样才能快点学完,然后去玩三国杀呢?”.这时候睿智 的凤老师从远处飘来,他 ...

  2. 前端模板<script type="text/template" id="tmpl">

    前端模板, 比连接字符串好用多了, 还可以使用循环\判断等语句, 减少工作量 <script type="text/template" id="member-tmp ...

  3. Get请求-Test版

    package com.fanqi.test; import java.io.DataInputStream; import java.io.IOException; import java.io.I ...

  4. python之MySQL学习——数据操作

    1.增 import pymysql as ps # 打开数据库连接 db = ps.connect(host=', database='test', charset='utf8') # 创建一个游标 ...

  5. devmapper: Thin Pool has 162394 free data blocks which is less than minimum required 163840 free data blocks

    问题: 制作镜像的时候报错 devmapper: Thin Pool has 162394 free data blocks which is less than minimum required 1 ...

  6. delphi xe学习随意记录

    学习来源(根据他们的资料整理) 论坛:http://www.coder163.com(有视频) 博客:http://del.cnblogs.com/(万一的博客) 1.1.1    命名规范的概述 1 ...

  7. 自动适应label

    CGFloat btnH = 300; NSString *text=@"你在这是NSString的对象方法,一个字符串实例调用该方法时,方法会通过传入的参数返回一个CGRect型数据,这个 ...

  8. hdu 3047 Zjnu Stadium 并查集高级应用

    Zjnu Stadium Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Tot ...

  9. <2014 05 09> 程序员:从C++转到Java需注意的地方

    最近想玩玩Android的APP开发,从C++角度来学习Java.Java可以说是一个优化精简版的C++,去除了底层C的很多特性.找了这篇文章. --------------------------- ...

  10. 调用百度API将地名转为经纬度

    最近做一道数据科学竞赛题,特征中有城市名和地名,需要转为经纬度来使用 故用python写了一个地名转经纬度的脚本,调用了百度地图的API,key在百度地图开放平台上申请 申请key的地方:http:/ ...