中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Android中的Xml 文檔怎么利用XmlPullParser 進行解析

發布時間:2020-12-07 16:38:23 來源:億速云 閱讀:162 作者:Leah 欄目:移動開發

這期內容當中小編將會給大家帶來有關Android中的Xml 文檔怎么利用XmlPullParser 進行解析 ,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

Android XmlPullParser 方式解析 Xml 文檔

xml 文件格式

<&#63;xml version="1.0" encoding="UTF-8"&#63;>
<persons>
  <person id="1">
    <name>張三</name>
    <age>22</age>
  </person>
  <person id="2">
    <name>李四</name>
    <age>20</age>
  </person>
</persons>

XmlPullParser 方式解析 xml 文件

import java.io.InputStream;
import java.io.OutputStream;
import java.util.ArrayList;
import java.util.List;
import org.xmlpull.v1.XmlPullParser;
import org.xmlpull.v1.XmlSerializer;
import com.eboy.domain.Person;
import android.util.Xml;
 
public class PersonService {
 public static List<Person> getPersons(InputStream xml) throws Exception {
  List<Person> persons = null;
  Person person = null;
  XmlPullParser pullParser = Xml.newPullParser();
  pullParser.setInput(xml, "UTF-8"); // 為Pull解釋器設置要解析的XML數據
  int event = pullParser.getEventType();
 
  while (event != XmlPullParser.END_DOCUMENT) {
 
   switch (event) {
 
   case XmlPullParser.START_DOCUMENT:
    persons = new ArrayList<Person>();
    break;
   case XmlPullParser.START_TAG:
    if ("person".equals(pullParser.getName())) {
     int id = Integer.valueOf(pullParser.getAttributeValue(0));
     person = new Person();
     person.setId(id);
    }
    if ("name".equals(pullParser.getName())) {
     String name = pullParser.nextText();
     person.setName(name);
    }
    if ("age".equals(pullParser.getName())) {
     int age = Integer.valueOf(pullParser.nextText());
     person.setAge(age);
    }
    break;
 
   case XmlPullParser.END_TAG:
    if ("person".equals(pullParser.getName())) {
     persons.add(person);
     person = null;
    }
    break;
 
   }
 
   event = pullParser.next();
  }
  return persons;
 }
 
 /**
  * 保存數據到xml文件中
  * @param persons
  * @param out
  * @throws Exception
  */
 public static void save(List<Person> persons, OutputStream out) throws Exception {
  XmlSerializer serializer = Xml.newSerializer();
  serializer.setOutput(out, "UTF-8");
  serializer.startDocument("UTF-8", true);
  serializer.startTag(null, "persons");
  for (Person person : persons) {
   serializer.startTag(null, "person");
   serializer.attribute(null, "id", person.getId().toString());
   serializer.startTag(null, "name");
   serializer.text(person.getName().toString());
   serializer.endTag(null, "name");
   serializer.startTag(null, "age");
   serializer.text(person.getAge().toString());
   serializer.endTag(null, "age");
   serializer.endTag(null, "person");
  }
  serializer.endTag(null, "persons");
  serializer.endDocument();
  out.flush();
  out.close();
 }
}

上述就是小編為大家分享的Android中的Xml 文檔怎么利用XmlPullParser 進行解析 了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

多伦县| 日土县| 苍山县| 江都市| 林周县| 康马县| 台北县| 福鼎市| 莱阳市| 龙海市| 海伦市| 康平县| 永嘉县| 汤原县| 通渭县| 博罗县| 廊坊市| 吉隆县| 多伦县| 嘉禾县| 田东县| 吉木萨尔县| 宝应县| 云和县| 东明县| 竹山县| 南陵县| 青岛市| 洪江市| 永福县| 凤阳县| 新和县| 九寨沟县| 简阳市| 镇康县| 巴青县| 桐柏县| 射阳县| 边坝县| 上虞市| 浦县|