xml解析之Pull

為了學(xué)習(xí)Pull解析xml,可以簡(jiǎn)單的做個(gè)小Demo

  • 第一步:以字符串的形式創(chuàng)建出xml。
    String str = "<?xml version="1.0" encoding="UTF-8"?>\n" +
    "<persons>\n" +
    " <person id="1">\n" +
    " <name>小羅</name>\n" +
    " <age>21</age>\n" +
    " </person>\n" +
    " <person id="2">\n" +
    " <name>android</name>\n" +
    " <age>15</age>\n" +
    " </person>\n" +
    "</persons>";

  • 第二步:根據(jù)xml文件封裝實(shí)體類(lèi):
    public class Person implements Serializable {
    int id;
    String name;
    int age;
    public void setAge(int age) {
    this.age = age;
    }
    public void setId(int id) {
    this.id = id;
    }
    public void setName(String name) {
    this.name = name;
    }
    @Override public String toString() {
    return "Person{" +
    "age=" + age +
    ", id=" + id +
    ", name='" + name + ''' + '}';
    }
    }

  • 第三步:創(chuàng)建解析方法:
    public List<Person> PullParseXml(InputStream inputStream) throws XmlPullParserException, IOException {
    List<Person> persons = new ArrayList<>();
    Person person = null;
    XmlPullParserFactory factory = XmlPullParserFactory.newInstance();
    XmlPullParser xmlPullParser = factory.newPullParser();
    xmlPullParser.setInput(inputStream, "utf-8");
    int eventType = xmlPullParser.getEventType();
    while (eventType != XmlPullParser.END_DOCUMENT) {
    switch (eventType) {
    // 解析到文檔開(kāi)始的時(shí)候
    case XmlPullParser.START_DOCUMENT:
    persons = new ArrayList<Person>();
    break;
    // 解析到xml標(biāo)簽的時(shí)候
    case XmlPullParser.START_TAG:
    if ("person".equals(xmlPullParser.getName())) {
    person = new Person();
    // 得到person元素的第一個(gè)屬性,也就是ID
    person.setId(Integer.parseInt(xmlPullParser.getAttributeValue(0)));
    } else if ("name".equals(xmlPullParser.getName())) {
    // 如果是name元素,則通過(guò)nextText()方法得到元素的值
    person.setName(xmlPullParser.nextText());
    } else if ("age".equals(xmlPullParser.getName())) {
    person.setAge(Integer.parseInt(xmlPullParser.nextText()));
    }
    break;
    // 解析到xml標(biāo)簽結(jié)束的時(shí)候
    case XmlPullParser.END_TAG:
    if ("person".equals(xmlPullParser.getName())) {
    persons.add(person);
    person = null;
    }
    break;
    }
    // 通過(guò)next()方法觸發(fā)下一個(gè)事件
    eventType = xmlPullParser.next();
    }
    return persons;
    }

  • 第四步:調(diào)用解析方法:
    byte[] bytes = str.getBytes();
    ByteArrayInputStream inputStream = new ByteArrayInputStream(bytes);
    try {
    persons = PullParseXml(inputStream);
    Log.d("TAG", "size = " + persons.size());
    Log.d("TAG", persons.get(0).toString());
    Log.d("TAG", persons.get(1).toString());
    } catch (Exception e) {
    e.printStackTrace();
    }

  • 第五步:運(yùn)行程序,你會(huì)得到如下Log:

Log.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 1 XML解析No29 【 XML:可拓展標(biāo)記語(yǔ)言,語(yǔ)言和HTML類(lèi)似,也是一種標(biāo)記語(yǔ)言。 特點(diǎn):標(biāo)記是自定義...
    征程_Journey閱讀 1,789評(píng)論 0 9
  • 在assets目錄下創(chuàng)建一個(gè)文件名為students.xml的XML文件. 創(chuàng)建一個(gè)與XML中節(jié)點(diǎn)相對(duì)應(yīng)的bean...
    A_Coder閱讀 302評(píng)論 0 2
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語(yǔ)法,類(lèi)相關(guān)的語(yǔ)法,內(nèi)部類(lèi)的語(yǔ)法,繼承相關(guān)的語(yǔ)法,異常的語(yǔ)法,線程的語(yǔ)...
    子非魚(yú)_t_閱讀 34,643評(píng)論 18 399
  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,539評(píng)論 19 139
  • 今年,2016,我們認(rèn)識(shí)的第七個(gè)年頭。 據(jù)說(shuō)七是一個(gè)神奇的數(shù)字,在人們心目中有些神秘。夫妻有七年之癢,古時(shí)有“七政...
    歐歐的日記閱讀 552評(píng)論 3 1

友情鏈接更多精彩內(nèi)容