首先,我們看一下什麼是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
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。