Android?XML數(shù)據(jù)解析要點介紹
1.XML數(shù)據(jù)要點介紹
首先我們來看看XML數(shù)據(jù)的一些要求以及概念:
2.三種解析XML方法的比較
3.SAX解析XML數(shù)據(jù)
核心代碼:
SAX解析類:SaxHelper.java
/** * Created by Jay on 2015/9/8 0008. */ public class SaxHelper extends DefaultHandler { private Person person; private ArrayList<Person> persons; //當前解析的元素標簽 private String tagName = null; /** * 當讀取到文檔開始標志是觸發(fā),通常在這里完成一些初始化操作 */ @Override public void startDocument() throws SAXException { this.persons = new ArrayList<Person>(); Log.i("SAX", "讀取到文檔頭,開始解析xml"); } /** * 讀到一個開始標簽時調(diào)用,第二個參數(shù)為標簽名,最后一個參數(shù)為屬性數(shù)組 */ @Override public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException { if (localName.equals("person")) { person = new Person(); person.setId(Integer.parseInt(attributes.getValue("id"))); Log.i("SAX", "開始處理person元素~"); } this.tagName = localName; } /** * 讀到到內(nèi)容,第一個參數(shù)為字符串內(nèi)容,后面依次為起始位置與長度 */ @Override public void characters(char[] ch, int start, int length) throws SAXException { //判斷當前標簽是否有效 if (this.tagName != null) { String data = new String(ch, start, length); //讀取標簽中的內(nèi)容 if (this.tagName.equals("name")) { this.person.setName(data); Log.i("SAX", "處理name元素內(nèi)容"); } else if (this.tagName.equals("age")) { this.person.setAge(Integer.parseInt(data)); Log.i("SAX", "處理age元素內(nèi)容"); } } } /** * 處理元素結(jié)束時觸發(fā),這里將對象添加到結(jié)合中 */ @Override public void endElement(String uri, String localName, String qName) throws SAXException { if (localName.equals("person")) { this.persons.add(person); person = null; Log.i("SAX", "處理person元素結(jié)束~"); } this.tagName = null; } /** * 讀取到文檔結(jié)尾時觸發(fā), */ @Override public void endDocument() throws SAXException { super.endDocument(); Log.i("SAX", "讀取到文檔尾,xml解析結(jié)束"); } //獲取persons集合 public ArrayList<Person> getPersons() { return persons; } } 然后我們在MainActivity.java中寫上寫上這樣一個方法,然后要解析XML的時候調(diào)用下 就好了~ private ArrayList<Person> readxmlForSAX() throws Exception { //獲取文件資源建立輸入流對象 InputStream is = getAssets().open("person1.xml"); //①創(chuàng)建XML解析處理器 SaxHelper ss = new SaxHelper(); //②得到SAX解析工廠 SAXParserFactory factory = SAXParserFactory.newInstance(); //③創(chuàng)建SAX解析器 SAXParser parser = factory.newSAXParser(); //④將xml解析處理器分配給解析器,對文檔進行解析,將事件發(fā)送給處理器 parser.parse(is, ss); is.close(); return ss.getPersons(); }
嗯,對了,忘記給大家說下我們是定義下面這樣一個person1.xml文件,然后放到assets目錄下的!文件內(nèi)容如下:person1.xml
<?xml version="1.0" encoding="UTF-8"?> <persons> <person id = "11"> <name>SAX解析</name> <age>18</age> </person> <person id = "13"> <name>XML1</name> <age>43</age> </person> </persons>
我們是把三種解析方式都糅合到一個demo中,所以最后才貼全部的效果圖,這里的話,貼下打印的Log,相信大家會對SAX解析XML流程更加明了:
另外,外面的空白文本也是文本節(jié)點哦!解析的時候也會走這些節(jié)點!
4.DOM解析XML數(shù)據(jù)
核心代碼:
DomHelper.java
/** * Created by Jay on 2015/9/8 0008. */ public class DomHelper { public static ArrayList<Person> queryXML(Context context) { ArrayList<Person> Persons = new ArrayList<Person>(); try { //①獲得DOM解析器的工廠示例: DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance(); //②從Dom工廠中獲得dom解析器 DocumentBuilder dbBuilder = dbFactory.newDocumentBuilder(); //③把要解析的xml文件讀入Dom解析器 Document doc = dbBuilder.parse(context.getAssets().open("person2.xml")); System.out.println("處理該文檔的DomImplemention對象=" + doc.getImplementation()); //④得到文檔中名稱為person的元素的結(jié)點列表 NodeList nList = doc.getElementsByTagName("person"); //⑤遍歷該集合,顯示集合中的元素以及子元素的名字 for(int i = 0;i < nList.getLength();i++) { //先從Person元素開始解析 Element personElement = (Element) nList.item(i); Person p = new Person(); p.setId(Integer.valueOf(personElement.getAttribute("id"))); //獲取person下的name和age的Note集合 NodeList childNoList = personElement.getChildNodes(); for(int j = 0;j < childNoList.getLength();j++) { Node childNode = childNoList.item(j); //判斷子note類型是否為元素Note if(childNode.getNodeType() == Node.ELEMENT_NODE) { Element childElement = (Element) childNode; if("name".equals(childElement.getNodeName())) p.setName(childElement.getFirstChild().getNodeValue()); else if("age".equals(childElement.getNodeName())) p.setAge(Integer.valueOf(childElement.getFirstChild().getNodeValue())); } } Persons.add(p); } } catch (Exception e) {e.printStackTrace();} return Persons; } }
代碼分析:
從代碼我們就可以看出DOM解析XML的流程,先整個文件讀入Dom解析器,然后形成一棵樹, 然后我們可以遍歷節(jié)點列表獲取我們需要的數(shù)據(jù)!
5.PULL解析XML數(shù)據(jù)
使用PULL解析XML數(shù)據(jù)的流程:
核心代碼:
public static ArrayList<Person> getPersons(InputStream xml)throws Exception { //XmlPullParserFactory pullPaser = XmlPullParserFactory.newInstance(); ArrayList<Person> persons = null; Person person = null; // 創(chuàng)建一個xml解析的工廠 XmlPullParserFactory factory = XmlPullParserFactory.newInstance(); // 獲得xml解析類的引用 XmlPullParser parser = factory.newPullParser(); parser.setInput(xml, "UTF-8"); // 獲得事件的類型 int eventType = parser.getEventType(); while (eventType != XmlPullParser.END_DOCUMENT) { switch (eventType) { case XmlPullParser.START_DOCUMENT: persons = new ArrayList<Person>(); break; case XmlPullParser.START_TAG: if ("person".equals(parser.getName())) { person = new Person(); // 取出屬性值 int id = Integer.parseInt(parser.getAttributeValue(0)); person.setId(id); } else if ("name".equals(parser.getName())) { String name = parser.nextText();// 獲取該節(jié)點的內(nèi)容 person.setName(name); } else if ("age".equals(parser.getName())) { int age = Integer.parseInt(parser.nextText()); person.setAge(age); } break; case XmlPullParser.END_TAG: if ("person".equals(parser.getName())) { persons.add(person); person = null; } break; } eventType = parser.next(); } return persons; }
使用Pull生成xml數(shù)據(jù)的流程:
核心代碼:
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 p : persons) { serializer.startTag(null, "person"); serializer.attribute(null, "id", p.getId() + ""); serializer.startTag(null, "name"); serializer.text(p.getName()); serializer.endTag(null, "name"); serializer.startTag(null, "age"); serializer.text(p.getAge() + ""); serializer.endTag(null, "age"); serializer.endTag(null, "person"); } serializer.endTag(null, "persons"); serializer.endDocument(); out.flush(); out.close(); }
6.代碼示例下載:
運行效果圖:
以上就是Android XML數(shù)據(jù)解析要點介紹的詳細內(nèi)容,更多關(guān)于Android XML數(shù)據(jù)解析的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Android ImageButton自定義按鈕的按下效果的代碼實現(xiàn)方法分享
這篇文章主要介紹了Android ImageButton自定義按鈕的按下效果的代碼實現(xiàn)方法,需要的朋友可以參考下2014-02-02Android 2.3 撥號上網(wǎng)流程從源碼角度進行分析
SIM卡實現(xiàn)撥號上網(wǎng)功能之前需要設(shè)置一番,這些設(shè)置步驟究竟做了哪些事情呢?我們現(xiàn)在就從源碼的角度進行分析2013-01-01Android中使用開源框架eventbus3.0實現(xiàn)fragment之間的通信交互
本文主要介紹了Android中使用開源框架eventbus3.0實現(xiàn)fragment之間的通信交互的方法,具有很好的參考價值,下面跟著小編一起來看下吧2017-02-02