<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context="com.example.generatexml.MainActivity" > <Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="短信备份1"
android:id="@+id/btn1"
android:onClick="backupSms1" /> <Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="短信备份2"
android:id="@+id/btn2"
android:layout_below="@id/btn1"
android:onClick="backupSms2" /> <Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="获取xml数据"
android:id="@+id/btn3"
android:layout_below="@id/btn2"
android:onClick="getXml" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/tv_get"
android:layout_below="@id/btn3"
android:onClick="getXml" />
/> </RelativeLayout>

 

package com.example.generatexml;

import java.io.File;
import java.io.FileOutputStream;
import java.util.ArrayList;
import java.util.List; import org.xmlpull.v1.XmlSerializer; import android.os.Bundle;
import android.os.Environment;
import android.support.v7.app.ActionBarActivity;
import android.util.Xml;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.Toast; import com.example.generatexml.domain.SmsInfo; public class MainActivity extends ActionBarActivity { private List<SmsInfo> list; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); list = new ArrayList<SmsInfo>();
long phone = 1880075555;
for(int i=0;i<10;i++)
{
SmsInfo info = new SmsInfo(i, System.currentTimeMillis(),"<短信内容"+i,phone+i+"",i/2+1);
list.add(info);
}
} public void backupSms1(View v){ try {
File file = new File(Environment.getExternalStorageDirectory(),"backup1.xml");
FileOutputStream fos = new FileOutputStream(file); StringBuffer sb = new StringBuffer(); sb.append("<?xml version=\"1.0\" encoding=\"utf-8\"?>"); sb.append("<smss>"); for(SmsInfo s :list)
{
sb.append("<sms>"); sb.append("<body>"+s.getBody()+"</body>");
sb.append("<type>"+s.getType()+"</type>");
sb.append("<addr>"+s.getAddr()+"</addr>");
sb.append("<date>"+s.getDate()+"</date>"); sb.append("</sms>"); } sb.append("</smss>"); fos.write(sb.toString().getBytes());
fos.close();
Toast.makeText(this, "保存成功", 0).show();
} catch (Exception e) { e.printStackTrace();
Toast.makeText(this, "保存失败", 0).show();
} } public void backupSms2(View v)
{ try {
XmlSerializer ser = Xml.newSerializer();
File file = new File(Environment.getExternalStorageDirectory(),"backup2.xml");
FileOutputStream os = new FileOutputStream(file);
ser.setOutput(os, "utf-8"); ser.startDocument("utf-8", true); ser.startTag(null, "smss"); for(SmsInfo s :list)
{
ser.startTag(null, "sms"); ser.attribute(null, "id", s.getId()+""); ser.startTag(null, "body");
ser.text(s.getBody());
ser.endTag(null, "body"); ser.startTag(null, "type");
ser.text(s.getType()+"");
ser.endTag(null, "type"); ser.startTag(null, "addr");
ser.text(s.getAddr());
ser.endTag(null, "addr"); ser.startTag(null, "date");
ser.text(s.getDate()+"");
ser.endTag(null, "date"); ser.endTag(null, "sms"); } ser.endTag(null, "smss"); ser.endDocument(); os.close(); Toast.makeText(this, "保存成功", 0).show(); } catch(Exception e) { e.printStackTrace();
Toast.makeText(this, "保存失败", 0).show();
}
} }
//解析xml文件
public void getXml(View v)
{
TextView tv = (TextView)this.findViewById(R.id.tv_get); try { InputStream is = MainActivity.this.getClassLoader().getResourceAsStream("backup2.xml");
List<SmsInfo> list = ParserXmlService.getSmsInfos(is); StringBuffer sb = new StringBuffer();
for(SmsInfo s:list)
{
sb.append(s.toString()); } tv.setText(sb.toString()); Toast.makeText(this, sb.toString(), 0).show(); } catch (Exception e) { e.printStackTrace();
Toast.makeText(this, "xml解析失败", 0).show();
} }

 

解析xml文件的service代码


package com.example.generatexml.service;

import java.io.InputStream;
import java.util.ArrayList;
import java.util.List; import org.xmlpull.v1.XmlPullParser; import android.util.Xml; import com.example.generatexml.domain.SmsInfo; public class ParserXmlService { public static List<SmsInfo> getSmsInfos(InputStream is) throws Exception
{ System.out.println("service");
XmlPullParser parser = Xml.newPullParser();
parser.setInput(is, "utf-8");
List<SmsInfo> list = null;
SmsInfo sms = null; int type = parser.getEventType(); while(type!=XmlPullParser.END_DOCUMENT)
{ switch(type)
{
case XmlPullParser.START_TAG:
if("smss".equals(parser.getName()))
{
list = new ArrayList<SmsInfo>();
}
else if("sms".equals(parser.getName()))
{
sms = new SmsInfo();
String id = parser.getAttributeValue(0);
sms.setId(Integer.parseInt(id));
}else if("body".equals(parser.getName()))
{
String body = parser.nextText();
sms.setBody(body);
}else if("addr".equals(parser.getName()))
{
String addr = parser.nextText();
sms.setAddr(addr);
}
else if("date".equals(parser.getName()))
{
String date = parser.nextText();
sms.setDate(Long.parseLong(date));
}
else if("type".equals(parser.getName()))
{
String infoType = parser.nextText();
sms.setDate(Integer.parseInt(infoType));
} break;
case XmlPullParser.END_TAG:
if("sms".equals(parser.getName()))
{
list.add(sms);
sms = null;
}
break;
}
type = parser.next();
} return list; } }

 

android 生成、pull解析xml文件的更多相关文章

  1. [android] 采用pull解析xml文件

    /***********2016年5月6日 更新**********************/ 知乎:Android 中有哪几种解析 xml 的类,官方推荐哪种 ? 以及它们的原理和区别? 刘吉财: ...

  2. android——使用pull解析xml文件

    1.persons.xml 将persons.xml文件放到src目录下.其代码如下: <?xml version='1.0' encoding='UTF-8' standalone='yes' ...

  3. Android中pull解析XML文件的简单使用

    首先,android中解析XML文件有三种方式,dom,sax,pull 这里先讲pull,稍候会说SAX和DOM pull是一种事件驱动的xml解析方式,不需要解析整个文档,返回的值是数值型,是推荐 ...

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

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

  5. Android -- 创建XML文件对象及其序列化, pull解析XML文件

    1. 创建XML文件对象及其序列化 示例代码:(模拟以xml格式备份短信到SD卡) SmsInfo.java, bean对象 /** * 短信的业务bean * @author Administrat ...

  6. 使用PULL解析XML文件

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

  7. pull解析xml文件

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

  8. dom4j生成和解析xml文件

    dom4j生成和解析xml文件 要生成和解析如下格式的xml文件: <?xml version="1.0" encoding="UTF-8"?> & ...

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

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

随机推荐

  1. java中父进程与子进程

    http://blog.csdn.NET/seelye/article/details/8269705

  2. jquery Ajax noConflict()

    如果幾個框架都在使用$作為標識符,那麼這個時候可以使用noConflict()處理衝突. 可以直接使用jquery代替簡寫,也可以定義變量,也可以將$賦值給ready函數,函數內部可以使用快捷方式,不 ...

  3. gitlab搭建与配置说明

    1. 概述 Gitlab分为社区版和企业版,此次安装的是社区版(gitlab-ce). 2. 准备 本次使用系统为Ubuntu16.04. 3. 安装 添加GitLab仓库,并安装到服务器上(将git ...

  4. Lodop强制分页LODOP.NewPage()和LODOP.NewPageA()

    使用Lodop打印控件打印时,有自动分页,有手动强制分页,也可以两者结合使用,在使用两者结合的时候注意LODOP.NewPage()和LODOP.NewPageA()的区别,如果前面打印项自动分页不止 ...

  5. 对 static const char* const str[] = {“string”} 的理解

    static const char* const str[] = {“string”} 静态常量型指针变量 static const char* 常量型变量 const str[] 这样修饰的作用为 ...

  6. 【BZOJ1558】等差数列(线段树)

    [BZOJ1558]等差数列(线段树) 题面 BZOJ 题解 可以说这道题已经非常毒瘤了 怎么考虑询问操作? 如果直接将一段数分解为等差数列? 太麻烦了.... 考虑相邻的数做差, 这样等差数列变为了 ...

  7. 【洛谷P1248】加工生产调度

    题目大意:某工厂收到了n个产品的订单,这n个产品分别在A.B两个车间加工,并且必须先在A车间加工后才可以到B车间加工.某个产品i在A.B两车间加工的时间分别为Ai.Bi.怎样安排这n个产品的加工顺序, ...

  8. max,min,Zip函数(十一)

    zip函数,拉链,传两个有序的参数,将他们一一对应为元祖形式 max,min比较默认比较一个元素,处理的是可迭代对象,相当于for循环取出每个元素进行比较,注意:不同类型之间不可比较 #!/usr/b ...

  9. 中南大学2018年ACM暑期集训前期训练题集(入门题) J : A Simple Problem

    毒瘤哇!为什么要用long long 啊!!!这个题没有加法操作啊,为什么会爆int啊!!!! 思路: http://www.cnblogs.com/buerdepepeqi/p/9048130.ht ...

  10. 决策树--信息增益,信息增益比,Geni指数的理解

    决策树 是表示基于特征对实例进行分类的树形结构       从给定的训练数据集中,依据特征选择的准则,递归的选择最优划分特征,并根据此特征将训练数据进行分割,使得各子数据集有一个最好的分类的过程.   ...