android操作XML的幾種方式

來源:互聯網
上載者:User

XML作為一種業界公認的資料交換格式,在各個平台與語言之上,都有廣泛使用和實現。其標準型,可靠性,安全性......毋庸置疑。在android平台上,我們要想實現資料存放區和資料交換,經常會使用到xml資料格式和xml檔案。

小提示:android中儲存資料一般有如下幾種:SharedPreferences(參數化),XML檔案,sqllite資料庫,網路,ContentProvider(內容提供者)等。

 

在android中,操作xml檔案,一般有幾種方式:SAX操作,Pull操作,DOM操作等。其中DOM的方式,可能是大家最熟悉的,也是符合W3C標準的。

1)

在java平台中,有諸如DOM4J這樣優秀的開源包,極大程度的方便大家使用DOM標準來操作XML檔案。在javascript中,不同的瀏覽器解析引擎,對DOM的解析和操作也略有差異(不過這不是本章介紹的重點)。而DOM的方式,也有其缺點。通常一次性載入xml檔案,再使用DOM的 api去進行解析,這樣很大程度的消耗記憶體,對效能會有一定影響。而我們的android手機,雖然配置在不斷的升級,但是記憶體方面,暫時還無法與傳統的PC去媲美。所以,在android開發中,個人不太推薦使用DOM的方式來解析和操作XML。

package cn.itcast.service;import java.io.InputStream;import java.util.ArrayList;import java.util.List;import javax.xml.parsers.DocumentBuilder;import javax.xml.parsers.DocumentBuilderFactory;import org.w3c.dom.Document;import org.w3c.dom.Element;import org.w3c.dom.Node;import org.w3c.dom.NodeList;import cn.itcast.model.Person;public class DomPersonService {     public List<Person> getPersons(InputStream stream) throws Throwable     {         List<Person> list =new ArrayList<Person>();         DocumentBuilderFactory factory =DocumentBuilderFactory.newInstance();         DocumentBuilder builder =factory.newDocumentBuilder();        Document dom = builder.parse(stream);//解析完成,並以dom樹的方式存放在記憶體中。比較消耗效能         //開始使用dom的api去解析         Element root = dom.getDocumentElement();//根項目        NodeList personNodes = root.getElementsByTagName("person");//返回所有的person元素節點        //開始遍曆啦        for(int i=0;i<personNodes.getLength();i++)        {            Person person =new Person();        Element personElement =(Element)personNodes.item(i);          person.setId(new Integer( personElement.getAttribute("id")));//將person元素節點的屬性節點id的值,賦給person對象          NodeList personChildrenNodes =personElement.getChildNodes();//擷取person節點的所有子節點          //遍曆所有子節點          for(int j=0;j<personChildrenNodes.getLength();j++)          {              //判斷子節點是否是元素節點(如果是文本節點,可能是空白文本,不處理)              if(personChildrenNodes.item(j).getNodeType()==Node.ELEMENT_NODE)              {                  //子節點--元素節點                  Element childNode =(Element)personChildrenNodes.item(j);                  if("name".equals(childNode.getNodeName()))                  {                      //如果子節點的名稱是“name”.將子項目節點的第一個子節點的值賦給person對象                      person.setName(childNode.getFirstChild().getNodeValue());                                        }else if("age".equals(childNode.getNodeValue()))                  {                       person.setAge(new Integer(childNode.getFirstChild().getNodeValue()));                  }              }                        }          list.add(person);        }        return list;     }}

2)

SAX(Simple API for XML),是一個使用非常廣泛的XML解析標準,通常使用Handler模式來處理XML文檔,這種處理模式和我們平常習慣的理解方式很不同,身邊也經常有一些朋友在剛接觸SAX的時候會覺得理解起來有些困難。其實SAX並不複雜,只不過是換了一種思維方式,正如它的名字所表示的,為了讓我們以更簡單的方式來處理XML文檔,下面我們就開始吧。

package cn.itcast.service;import java.io.InputStream;import java.util.ArrayList;import java.util.List;import javax.xml.parsers.SAXParser;import javax.xml.parsers.SAXParserFactory;import org.xml.sax.Attributes;import org.xml.sax.SAXException;import org.xml.sax.helpers.DefaultHandler;import cn.itcast.model.Person;public class SAXPersonService {   public List<Person> getPersons(InputStream inStream) throws Throwable   {       SAXParserFactory factory = SAXParserFactory.newInstance();//原廠模式還是單例模式?       SAXParser parser =factory.newSAXParser();       PersonParse personParser =new PersonParse();       parser.parse(inStream, personParser);       inStream.close();       return personParser.getPerson();   }   private final class PersonParse extends DefaultHandler   {           private List<Person> list = null;    Person person =null;    private String tag=null;        public List<Person> getPerson() {        return list;    }    @Override    public void startDocument() throws SAXException {        list =new ArrayList<Person>();    }    @Override    public void startElement(String uri, String localName, String qName,            Attributes attributes) throws SAXException {        if("person".equals(localName))        {            //xml元素節點開始時觸發,是“person”            person = new Person();            person.setId(new Integer(attributes.getValue(0)));        }        tag =localName;//儲存元素節點名稱    }    @Override    public void endElement(String uri, String localName, String qName)            throws SAXException {        //元素節點結束時觸發,是“person”        if("person".equals(localName))        {            list.add(person);            person=null;        }        tag =null;//結束時,需要清空tag        }    @Override    public void characters(char[] ch, int start, int length)            throws SAXException {        if(tag!=null)        {            String data = new String(ch,start,length);           if("name".equals(tag))           {               person.setName(data);                          }else if("age".equals(tag))           {               person.setAge(new Integer(data));           }        }    }                         }}

3)

 Pull解析和Sax解析很相似,都是輕量級的解析,在Android的核心中已經嵌入了Pull,所以我們不需要再添加第三方jar包來支援Pull。Pull解析和Sax解析不一樣的地方有(1)pull讀取xml檔案後觸發相應的事件調用方法返回的是數字(2)pull可以在程式中控制想解析到哪裡就可以停止解析。

package cn.itcast.service;import java.io.InputStream;import java.io.Writer;import java.util.ArrayList;import java.util.List;import org.xmlpull.v1.XmlPullParser;import org.xmlpull.v1.XmlSerializer;import android.util.Xml;import cn.itcast.model.Person;public class PullPersonService {    //儲存xml檔案    public static void saveXML(List<Person> list,Writer write)throws Throwable    {        XmlSerializer serializer =Xml.newSerializer();//序列化        serializer.setOutput(write);//輸出資料流        serializer.startDocument("UTF-8", true);//開始文檔        serializer.startTag(null, "persons");        //迴圈去添加person        for (Person person : list) {            serializer.startTag(null, "person");            serializer.attribute(null, "id", person.getId().toString());//設定id屬性及屬性值            serializer.startTag(null, "name");            serializer.text(person.getName());//文本節點的文本值--name            serializer.endTag(null, "name");            serializer.startTag(null, "age");            serializer.text(person.getAge().toString());//文本節點的文本值--age            serializer.endTag(null, "age");            serializer.endTag(null, "person");        }        serializer.endTag(null, "persons");        serializer.endDocument();        write.flush();        write.close();    }     public List<Person> getPersons(InputStream stream) throws Throwable     {         List<Person> list =null;        Person person =null;        XmlPullParser parser =Xml.newPullParser();        parser.setInput(stream,"UTF-8");        int type =parser.getEventType();//產生第一個事件        //只要當前事件類型不是”結束文檔“,就去迴圈        while(type!=XmlPullParser.END_DOCUMENT)        {        switch (type) {        case XmlPullParser.START_DOCUMENT:        list =    new ArrayList<Person>();            break;        case XmlPullParser.START_TAG:            String name=parser.getName();//擷取解析器當前指向的元素名稱            if("person".equals(name))            {                person =new Person();                person.setId(new Integer(parser.getAttributeValue(0)));            }            if(person!=null)            {                if("name".equals(name))                {                    person.setName(parser.nextText());//擷取解析器當前指向的元素的下一個文本節點的文本值                }                if("age".equals(name))                {                    person.setAge(new Integer(parser.nextText()));                }            }            break;        case XmlPullParser.END_TAG:            if("person".equals(parser.getName()))            {                list.add(person);                person=null;            }            break;        }        type=parser.next();//這句千萬別忘了哦        }         return list;     }}


下面是Model層的Person類的代碼:

package cn.itcast.model;public class Person {private Integer id;public Integer getId() {    return id;}public void setId(Integer id) {    this.id = id;}private String name;public String getName() {    return name;}public void setName(String name) {    this.name = name;}private Integer age;public Integer getAge() {    return age;}public void setAge(Integer age) {    this.age = age;}public Person(){}public Person(Integer id, String name, Integer age) {        this.id = id;    this.name = name;    this.age = age;}@Overridepublic String toString() {    return "Person [id=" + id + ", name=" + name + ", age=" + age + "]";}}


看完本文中的樣本,相信你已經理解了android中訪問和操作xml資料的幾種方式。讀者不妨動手去敲代碼、調試,可以很方便的利用模擬器進行單元測試。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.