android之XmlSerializer序列化XML(寫入)

     首先,咱們看一下什麼是serializer,serializer就是串行化,又名序列化。它可並不僅是簡單的把對象保存在存儲器上,它可使咱們在流中傳輸對象,使對象變的能夠像基本數據同樣傳遞。html

最終效果圖如上java

如今粘貼主要代碼:android

main.xml
api

[xhtml] view plaincopyapp

  1. <?xml version="1.0" encoding="utf-8"?>  ide

  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  測試

  3.     android:orientation="vertical"  this

  4.     android:layout_width="fill_parent"  編碼

  5.     android:layout_height="fill_parent"  spa

  6.     >  

  7. <TextView    

  8.     android:layout_width="fill_parent"   

  9.     android:layout_height="wrap_content"   

  10.     android:id="@+id/textView"  

  11.     />  

  12. </LinearLayout>  

activity的代碼

 

[java] view plaincopy

  1. package cn.com.xmlseriliazer;  

  2.   

  3. import java.io.StringWriter;  

  4. import java.util.ArrayList;  

  5.   

  6. import org.xmlpull.v1.XmlPullParserFactory;  

  7. import org.xmlpull.v1.XmlSerializer;  

  8.   

  9. import android.app.Activity;  

  10. import android.os.Bundle;  

  11. import android.widget.TextView;  

  12. /** 

  13.  *  

  14.  * @author chenzheng_java 

  15.  * @description 測試經過XmlSerilizer生成xml文件 

  16.  * 


  17.  * 

  18.  */  

  19. public class XmlSerializerActivity extends Activity {  

  20.     @Override  

  21.     public void onCreate(Bundle savedInstanceState) {  

  22.         super.onCreate(savedInstanceState);  

  23.         setContentView(R.layout.main);  

  24.           

  25.         String result = produceXml();  

  26.         TextView textView = (TextView)this.findViewById(R.id.textView);  

  27.         textView.setText(result);  

  28.           

  29.     }  

  30.     /** 

  31.      *  

  32.      * @return 生成的xml文件的字符串表示 

  33.      */  

  34.     private String produceXml(){  

  35.           

  36.         StringWriter stringWriter = new StringWriter();  

  37.         ArrayList<Beauty> beautyList = getData();  

  38.         try {  

  39.             // 獲取XmlSerializer對象  

  40.             XmlPullParserFactory factory = XmlPullParserFactory.newInstance();  

  41.             XmlSerializer xmlSerializer = factory.newSerializer();  

  42.             // 設置輸出流對象  

  43.             xmlSerializer.setOutput(stringWriter);  

  44.             /* 

  45.              * startDocument(String encoding, Boolean standalone)encoding表明編碼方式 

  46.              * standalone  用來表示該文件是否呼叫其它外部的文件。 

  47.              * 若值是 」yes」 表示沒有呼叫外部規則文件,若值是 」no」 則表示有呼叫外部規則文件。默認值是 「yes」。 

  48.              */  

  49.             xmlSerializer.startDocument("utf-8"true);  

  50.             xmlSerializer.startTag(null"beauties");  

  51.             for(Beauty beauty:beautyList){  

  52.                 /* 

  53.                  * startTag (String namespace, String name)這裏的namespace用於惟一標識xml標籤 

  54.                  *XML 命名空間屬性被放置於某個元素的開始標籤之中,並使用如下的語法: 

  55.                     xmlns:namespace-prefix="namespaceURI" 

  56.                     當一個命名空間被定義在某個元素的開始標籤中時,全部帶有相同前綴的子元素都會與同一個命名空間相關聯。 

  57.                     註釋:用於標示命名空間的地址不會被解析器用於查找信息。其唯一的做用是賦予命名空間一個唯一的名稱。不過,不少公司經常會做爲指針來使用命名空間指向某個實存的網頁,這個網頁包含着有關命名空間的信息。 

  58.                  */  

  59.                 xmlSerializer.startTag(null"beauty");  

  60.                   

  61.                 xmlSerializer.startTag(null"name");  

  62.                 xmlSerializer.text(beauty.getName());  

  63.                 xmlSerializer.endTag(null"name");  

  64.                   

  65.                 xmlSerializer.startTag(null"age");  

  66.                 xmlSerializer.text(beauty.getAge());  

  67.                 xmlSerializer.endTag(null"age");  

  68.                   

  69.                 xmlSerializer.endTag(null"beauty");  

  70.             }  

  71.             xmlSerializer.endTag(null"beauties");  

  72.             xmlSerializer.endDocument();  

  73.         } catch (Exception e) {  

  74.             e.printStackTrace();  

  75.         }  

  76.         return stringWriter.toString();  

  77.   

  78.     }  

  79.       

  80.     /** 

  81.      *  

  82.      * @return 包含了衆多美女信息的集合 

  83.      */  

  84.     private ArrayList<Beauty> getData(){  

  85.         ArrayList<Beauty> beautyList = new ArrayList<Beauty>();  

  86.           

  87.         Beauty yangmi = new Beauty("楊冪""23");  

  88.         Beauty linzhiling = new Beauty("林志玲""28");  

  89.   

  90.         beautyList.add(yangmi);  

  91.         beautyList.add(linzhiling);  

  92.           

  93.         return beautyList;  

  94.     }  

  95.       

  96.     /** 

  97.      *  

  98.      * @author chenzheng_java 

  99.      *  美人實體類 

  100.      */  

  101.     private class Beauty{  

  102.         String name;  

  103.         String age ;  

  104.         public String getName() {  

  105.             return name;  

  106.         }  

  107.         public void setName(String name) {  

  108.             this.name = name;  

  109.         }  

  110.         public String getAge() {  

  111.             return age;  

  112.         }  

  113.         public void setAge(String age) {  

  114.             this.age = age;  

  115.         }  

  116.         @Override  

  117.         public String toString() {  

  118.             return "Beauty [age=" + age + ", name=" + name + "]";  

  119.         }  

  120.         public Beauty(String name, String age) {  

  121.             this.name = name;  

  122.             this.age = age;  

  123.         }  

  124.         public Beauty(){  

  125.               

  126.         }  

  127.           

  128.     }  

  129.       

  130. }  

 

其餘都爲默認。

 由代碼咱們能夠看到,其實使用xmlserializer生成xml也是至關容易的。基本的步驟和解析xml差很少。這裏就很少說話了。詳情請看api。

相關文章
相關標籤/搜索