android資料存放區與訪問之使用pull解析器

來源:互聯網
上載者:User

 Pull解析器是一個開源的java項目,既可以用於android,也可以用於JavaEE。如果用在javaEE需要把其jar檔案放入類路徑中,因為Android已經整合進了Pull解析器,所以無需添加任何jar檔案。android系統本身使用到的各種xml檔案,其內部也是採用Pull解析器進行解析的。 Pull解析器的運行方式與 SAX 解析器相似。它提供了類似的事件,如:開始元素和結束元素事件,使用parser.next()可以進入下一個元素並觸發相應事件。跟SAX不同的是, Pull解析器產生的事件是一個數字,而非方法,因此可以使用一個switch對感興趣的事件進行處理。當元素開始解析時,調用parser.nextText()方法可以擷取下一個Text類型節點的值。

如下為要解析的XML檔案

檔案名稱:persons.xml

<?xml version="1.0" encoding="UTF-8"?><persons>    <person id=“18">        <name>allen</name>        <age>36</age>    </person>    <person id=“28">        <name>james</name>        <age>25</age>    </person></persons>

例子定義了一個javabean用於存放上面解析出來的xml內容, 這個javabean為Person,如下:

public class Person {private Integer id;private String name;private Short age;public Integer getId() {return id;}public void setId(Integer id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}public Short getAge() {return age;}public void setAge(Short age) {this.age = age;}}

使用Pull解析器讀取itcast.xml的代碼如下:

import org.xmlpull.v1.XmlPullParser;import android.util.Xml;import cn.itcast.xml.domain.Person;public class PullXMLReader {public static List<Person> readXML(InputStream inStream) {    XmlPullParser parser = Xml.newPullParser();    try {    parser.setInput(inStream, "UTF-8");    int eventType = parser.getEventType();    Person currentPerson = null;    List<Person> persons = null;    while (eventType != XmlPullParser.END_DOCUMENT) {        switch (eventType) {        case XmlPullParser.START_DOCUMENT://文檔開始事件,可以進行資料初始化處理            persons = new ArrayList<Person>();            break;        case XmlPullParser.START_TAG://開始元素事件            String name = parser.getName();            if (name.equalsIgnoreCase("person")) {                currentPerson = new Person();                currentPerson.setId(new Integer(parser.getAttributeValue(null, "id")));            } else if (currentPerson != null) {                if (name.equalsIgnoreCase("name")) {                    currentPerson.setName(parser.nextText());// 如果後面是Text節點,即返回它的值                } else if (name.equalsIgnoreCase("age")) {                    currentPerson.setAge(new Short(parser.nextText()));                }            }            break;        case XmlPullParser.END_TAG://結束元素事件            if (parser.getName().equalsIgnoreCase("person") && currentPerson != null) {                persons.add(currentPerson);                currentPerson = null;            }            break;        }        eventType = parser.next();    }    inStream.close();    return persons;    } catch (Exception e) {        e.printStackTrace();    }    return null;}}

使用Pull解析器產生XML檔案

有些時候,我們需要產生一個XML檔案,產生XML檔案的方法有很多,如:可以只使用一個StringBuilder組拼XML內容,然後把內容寫入到檔案中;或者使用DOM API產生XML檔案,或者也可以使用pull解析器產生XML檔案,這裡推薦大家使用Pull解析器。

使用Pull解析器產生一個與persons.xml

使用代碼如下(產生XML檔案):
File xmlFile = new File("persons.xml");
FileOutputStream outStream = new FileOutputStream(xmlFile);
OutputStreamWriter outStreamWriter = new OutputStreamWriter(outStream, "UTF-8");
BufferedWriter writer = new BufferedWriter(outStreamWriter);
writeXML(persons, writer);
writer.flush();
writer.close();
如果只想得到產生的xml字串內容,可以使用StringWriter:
StringWriter writer = new StringWriter();
writeXML(persons, writer);
String content = writer.toString();

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.