首先,我们看一下什么是serializer,serializer就是串行化,又名序列化。它可并不只是简单的把对象保存在存储器上,它可以使我们在流中传输对象,使对象变的可以像基本数据一样传递。
XmlSerializer是针对XML进行序列化的类库,我们先来看一下里面的常用方法:
基本方法
1.创建一个xml文件的序列化器,返回的是一个Xml的 Serializer 对象。
XmlSerializer = Xml.newSerializer();
2.设置序列化器的输出路径和编码方式
FileOutputStream = new FileOutputStream(new File(Environment.getExternalStorageDirectory(),"文件名.xml")); XmlSerializer.setOutput(FileOutputStream, "编码");
3.声明xml文件头(写入XML文件中的声明头)
serializer.startDocument("xml声明的编码", 文档是否独立);
4.声明子节点
Serializer.startTag(nameSpace,String "节点名");
5.声明节点属性
Serializer.attribute(命名空间,属性名,属性值);
6.声明节点中的TextNode
Serializer.txt(文本值);
7.设置节点尾标签
Serializer.endTag(命名空间, "节点名");
8.写Xml文件尾表示Xml文件结束。
Serializer.endDocument();
9.关闭资源
FileOutputStream.close();
示例
最终效果图如上
现在粘贴主要代码:
main.xml
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent" > <TextView android:layout_width="fill_parent" android:layout_height="wrap_content" android:id="@+id/textView" /> </LinearLayout>
activity的代码
package cn.com.xmlseriliazer; import java.io.StringWriter; import java.util.ArrayList; import org.xmlpull.v1.XmlPullParserFactory; import org.xmlpull.v1.XmlSerializer; import android.app.Activity; import android.os.Bundle; import android.widget.TextView; /** * * @author chenzheng_java * @description 测试通过XmlSerilizer生成xml文件 * @since 2011/03/03 * */ public class XmlSerializerActivity extends Activity { @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); String result = produceXml(); TextView textView = (TextView)this.findViewById(R.id.textView); textView.setText(result); } /** * * @return 生成的xml文件的字符串表示 */ private String produceXml(){ StringWriter stringWriter = new StringWriter(); ArrayList<Beauty> beautyList = getData(); try { // 获取XmlSerializer对象 XmlPullParserFactory factory = XmlPullParserFactory.newInstance(); XmlSerializer xmlSerializer = factory.newSerializer(); // 设置输出流对象 xmlSerializer.setOutput(stringWriter); /* * startDocument(String encoding, Boolean standalone)encoding代表编码方式 * standalone 用来表示该文件是否呼叫其它外部的文件。 * 若值是 ”yes” 表示没有呼叫外部规则文件,若值是 ”no” 则表示有呼叫外部规则文件。默认值是 “yes”。 */ xmlSerializer.startDocument("utf-8", true); xmlSerializer.startTag(null, "beauties"); for(Beauty beauty:beautyList){ /* * startTag (String namespace, String name)这里的namespace用于唯一标识xml标签 *XML 命名空间属性被放置于某个元素的开始标签之中,并使用以下的语法: xmlns:namespace-prefix="namespaceURI" 当一个命名空间被定义在某个元素的开始标签中时,所有带有相同前缀的子元素都会与同一个命名空间相关联。 注释:用于标示命名空间的地址不会被解析器用于查找信息。其惟一的作用是赋予命名空间一个惟一的名称。不过,很多公司常常会作为指针来使用命名空间指向某个实存的网页,这个网页包含着有关命名空间的信息。 */ xmlSerializer.startTag(null, "beauty"); xmlSerializer.startTag(null, "name"); xmlSerializer.text(beauty.getName()); xmlSerializer.endTag(null, "name"); xmlSerializer.startTag(null, "age"); xmlSerializer.text(beauty.getAge()); xmlSerializer.endTag(null, "age"); xmlSerializer.endTag(null, "beauty"); } xmlSerializer.endTag(null, "beauties"); xmlSerializer.endDocument(); } catch (Exception e) { e.printStackTrace(); } return stringWriter.toString(); } /** * * @return 包含了众多美女信息的集合 */ private ArrayList<Beauty> getData(){ ArrayList<Beauty> beautyList = new ArrayList<Beauty>(); Beauty yangmi = new Beauty("杨幂", "23"); Beauty linzhiling = new Beauty("林志玲", "28"); beautyList.add(yangmi); beautyList.add(linzhiling); return beautyList; } /** * * @author chenzheng_java * 美人实体类 */ private class Beauty{ String name; String age ; public String getName() { return name; } public void setName(String name) { this.name = name; } public String getAge() { return age; } public void setAge(String age) { this.age = age; } @Override public String toString() { return "Beauty [age=" + age + ", name=" + name + "]"; } public Beauty(String name, String age) { this.name = name; this.age = age; } public Beauty(){ } } }
其他都为默认。
由代码我们可以看到,其实使用xmlserializer生成xml也是相当容易的。基本的步骤和解析xml差不多。这里就不多说话了。详情请看api。