編輯:關於android開發
除了可以使用SAX和DOM解析XML文件,也可以使用Android內置的Pull解析器解析XML文件。Pull解析器的運行方式與SAX解析器相似。它也是事件觸發的。Pull解析方式讓應用程序完全控制文檔該怎麼樣被解析。比如開始和結束元素事件,使用parser.next()可以進入下一個元素並觸發相應事件。通過Parser.getEventType()方法來取得事件的代碼值,解析是在開始時就完成了大部分的處理。事件將作為數值代碼被發送,因此可以使用一個switch對感興趣的事件進行處理。Pull解析是一個遍歷文檔的過程,每次調用next()、nextTag()、nextToken()和nextText()都會向前推進文檔,並使parser停留在某些事件上面,但是不能倒退。然後把文檔設置給Parser。它允許用戶的應用程序代碼從解析器中獲取事件,這與SAX解析器自動將事件推入處理程序相反。Pull解析器小巧輕便,解析速度快,簡單易用,非常適合在Android移動設備中使用,Android系統內部在解析各種XML時也是用Pull解析器,Android官方推薦開發者們使用Pull解析技術。Pull解析技術是第三方開發的開源技術,它同樣可以應用於JavaSE開發。
SAX與Pull的區別:SAX解析器的工作方式是自動將事件處理器進行處理,因此不能控制事件的處理主動結束;而Pull解析器的工作方式為允許應用程序代碼主動從解析器中獲取事件,正因為是主動獲取事件,因此可以在滿足了需要的條件後不再獲取事件,結束解析。
優點: 解析速度快,占用資源少。
缺點: 數據不持久。
使用場合: 對於XML文檔較大但只需要文檔的一部分。
XmlPullParser parser = Xml.newPullParser(); parser.setInput(inputStream, "UTF-8");//設置事件源編碼
int eventType = parser.getEventType();
//判斷是否到結束節點 while (eventType != XmlPullParser.END_DOCUMENT) { switch (eventType) { //文檔開始事件,可以進行數據初始化處理 case XmlPullParser.START_DOCUMENT: ... break; //開始元素事件 case XmlPullParser.START_TAG: ... break; //結束元素事件 case XmlPullParser.END_TAG: ... break; } eventType = parser.next(); }
調用parser.nextText()方法可以獲取下一個Text類型元素的值。
<?xml version="1.0" encoding="UTF-8"?> <persons> <person id="23"> <name>liming</name> <age>30</age> </person> <person id="20"> <name>lixiangmei</name> <age>25</age> </person> </persons>
如果沒有raw文件夾,就在res文件夾下創建一個raw文件夾,並創建xml文件。
<Button android:id="@+id/pull_button" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_centerHorizontal="true" android:layout_marginTop="@dimen/fab_margin" android:gravity="center_horizontal" android:text="@string/PULL" /> <TextView android:id="@+id/text" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Hello World!" />
package com.zhangmiao.analyzexmldemo; import android.util.Xml; import org.xmlpull.v1.XmlPullParser; import org.xmlpull.v1.XmlSerializer; import java.io.InputStream; import java.util.ArrayList; import java.util.List; /** * Created by zhangmiao on 2016/12/14. */ public class AnalyzePull { public static List<Person> readXML(InputStream inputStream) { XmlPullParser parser = Xml.newPullParser(); try { parser.setInput(inputStream, "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<>(); 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()); } 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(); } inputStream.close(); return persons; } catch (Exception e) { e.printStackTrace(); } return null; } }
package com.zhangmiao.analyzexmldemo; import android.os.Bundle; import android.support.design.widget.FloatingActionButton; import android.support.design.widget.Snackbar; import android.support.v7.app.AppCompatActivity; import android.support.v7.widget.Toolbar; import android.util.Log; import android.view.View; import android.view.Menu; import android.view.MenuItem; import android.widget.Button; import android.widget.TextView; import org.xml.sax.InputSource; import java.io.BufferedWriter; import java.io.File; import java.io.FileOutputStream; import java.io.InputStream; import java.io.OutputStreamWriter; import java.io.StringWriter; import java.util.List; import javax.xml.parsers.SAXParser; import javax.xml.parsers.SAXParserFactory; public class MainActivity extends AppCompatActivity implements View.OnClickListener { private static final String TAG = "AnalyzeXMLDemo"; private TextView mTextView; private InputStream inputStream; @Override protected void onCreate(Bundle savedInstanceState) { Log.v(TAG, "onCreate"); super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar); setSupportActionBar(toolbar); FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab); fab.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG) .setAction("Action", null).show(); } }); Button pullButton = (Button)findViewById(R.id.pull_button); mTextView = (TextView) findViewById(R.id.text); pullButton.setOnClickListener(this); } @Override public void onClick(View v) { String result = ""; inputStream = getResources().openRawResource(R.raw.itcase); switch (v.getId()) { case R.id.pull_button: result += "--------- PULL ---------" + "\n"; File xmlFile = new File("myitcast.xml"); if (inputStream == null) { result = "inputStream is null"; } else { List<Person> personList = AnalyzePull.readXML(inputStream); if (personList != null) { for (int i = 0; i < personList.size(); i++) { String message = "id = " + personList.get(i).getId() + " , name = " + personList.get(i).getName() + " , age = " + personList.get(i).getAge() + ".\n"; result += message; } } } mTextView.setText(result); break; default: break; } } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.menu_main, menu); return true; } @Override public boolean onOptionsItemSelected(MenuItem item) { // Handle action bar item clicks here. The action bar will // automatically handle clicks on the Home/Up button, so long // as you specify a parent activity in AndroidManifest.xml. int id = item.getItemId(); //noinspection SimplifiableIfStatement if (id == R.id.action_settings) { return true; } return super.onOptionsItemSelected(item); } }
參考文章:
http://www.open-open.com/lib/view/open1392780226397.html
http://www.cnblogs.com/weixing/archive/2013/08/07/3243366.html
http://www.tuicool.com/articles/IvQvyq
Android數據庫相關整理,android數據庫整理今天對Android中數據庫相關的操作和代碼做了一個整理,便於自己之後的查閱。主要內容有: 1.原生數據庫寫法 2.
Failed to apply plugin [id 'com.android.application'] 和 Could not find com.an
Volley,volley框架 一 網絡請求 1.get方式請求數據 // 1 創建一個請求隊列 RequestQueue requestQueue = Vo
沉浸式,沉浸式狀態欄第一步: protected void onCreate(Bundle savedInstanceState) { super.o
Android應用項目中BaseAdapter、SimpleAdapte