編輯:關於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數據庫相關整理,android數據庫整理今天對Android中數據庫相關的操作和代碼做了一個整理,便於自己之後的查閱。主要內容有: 1.原生數據庫寫法 2.
Failed to apply plugin [id 'com.android.application'] 和 Could not find com.android.tools.build:gradle:2.XX的最正確的解決方法,applyplugin
Failed to apply plugin [id 'com.android.application'] 和 Could not find com.an
Volley,volley框架
Volley,volley框架 一 網絡請求 1.get方式請求數據 // 1 創建一個請求隊列 RequestQueue requestQueue = Vo
沉浸式,沉浸式狀態欄
沉浸式,沉浸式狀態欄第一步: protected void onCreate(Bundle savedInstanceState) { super.o
Android應用項目中BaseAdapter、SimpleAdapter和ArrayAdapter中的三種適配器,simplearrayadapter
Android應用項目中BaseAdapter、SimpleAdapte