Android平台——解析XML数据
来源:互联网 发布:什么是数据科学家 编辑:程序博客网 时间:2024/06/06 02:57
XML(Extensible Markup Language)可扩展标记语言,HTML主要用于显示数据,有预定义标签,而xml主要用于存储和传输数据,没有预定义的标签
在Android中,常见的XML解析器分别为DOM解析器、SAX解析器和PULL解析器
(1)DOM解析器
DOM是一种树型结构,它允许开发人员使用内置的api来对遍历xml数据,检索其中的信息。当DOM解析xml数据时,需要读入整个文档,如果文档过大,将会十分耗内存。
(2)SAX解析器
SAX是一种基于事件的解析方式, Android并未提供对Java StAX API的支持。
(3)PULL解析器
PULL解析器类似SAX,也是基于事件的,且PULL小巧轻便,简单易用,解析速度也快,非常适合在Android移动设备中使用。
下面将对books.xml这个文件进行解析,books.xml代码如下:
<?xml version="1.0" encoding="utf-8"?><books> <book id="1"> <name>假如给我三天光明</name> <auther>海伦凯勒</auther> </book> <book id="2"> <name>水浒传</name> <auther>施耐庵</auther> </book> <book id="3"> <name>疯狂Android讲义</name> <auther>李刚</auther> </book></books>
使用DOM解析器解析:
DocumentBuilderFactory builderFactory = DocumentBuilderFactory.newInstance(); DocumentBuilder builder = builderFactory.newDocumentBuilder(); // builder.parse()有多种参数,可以根据项目要求自行选择 Document document = builder.parse(new File("books.xml")); // 得到根节点<books> Element element = document.getDocumentElement(); // 得到子节点<book>,返回一个list NodeList nodeList = element.getElementsByTagName("book"); // 遍历每一个<book>子节点中的内容 for (int i = 0; i < nodeList.getLength(); i++) { Element book = (Element) nodeList.item(i); System.out.println("id:" + book.getAttribute("id")); System.out.println("书名:" + book.getElementsByTagName("name").item(0).getTextContent()); System.out.println("作者:" + book.getElementsByTagName("auther").item(0).getTextContent()); }
运行结果:
使用PULL解析器解析:
public class MainActivity extends Activity { private int type; private TextView text; // 得到PULL解析器的一个实例 private XmlPullParser mXmlPullParser = Xml.newPullParser(); private StringBuilder sb = new StringBuilder(); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); text = (TextView) findViewById(R.id.text); new Thread() { public void run() { try { // 设置数据源 mXmlPullParser.setInput(getAssets().open("books.xml"), "utf-8"); // 得到事件类型,比如START_DOCUMENT,END_DOCUMENT,START_TAG,END_TAG.... type = mXmlPullParser.getEventType(); while (type != XmlPullParser.END_DOCUMENT) { String tagName = mXmlPullParser.getName(); switch (mXmlPullParser.getEventType()) { case XmlPullParser.START_TAG: if (tagName.equals("book")) { // 获取属性值 sb.append("id:" + mXmlPullParser.getAttributeValue(null, "id") + "\n"); } else if (tagName.equals("name")) { // 获取name标签的值 sb.append("书名:" + mXmlPullParser.nextText() + "\n"); } else if (tagName.equals("auther")) { // 获取auther标签的值 sb.append("作者:" + mXmlPullParser.nextText() + "\n"); } break; case XmlPullParser.END_TAG: break; } // 下一个标签 type = mXmlPullParser.next(); } } catch (XmlPullParserException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } runOnUiThread(new Runnable() { public void run() { text.setText(sb.toString()); } }); }; }.start(); }}
执行结果:
0 0
- Android平台——解析XML数据
- Android解析数据—XML格式数据
- MTK平台解析XML数据
- Android XML数据解析——SAX解析
- android平台xml资源解析
- 有关Android 平台解析XML
- Android---解析XML数据
- Android 解析XML数据
- Android XML数据解析
- Android XML数据解析
- android解析XML数据
- android XML数据解析
- Android解析xml数据
- Android解析XML数据
- Android基础笔记——Pull解析XML格式数据
- Android基础笔记——SAX解析XML格式数据
- Android XML数据解析——pull技术
- Android基础—XML数据解析的三种方式
- PowerPoint使用技巧
- java注释
- 通过name或者id获取value
- Javascript 面试题
- (OK) cannot locate symbol referenced by (math symbols in libgcc.a sneaking into dynamic libraries)
- Android平台——解析XML数据
- Ubuntu搭建HelixServer时碰到的一些问题
- SCPPO(五):解决MVC中Json传输数据量问题
- ORG的JSON解析
- soapui笔记10:测试流程控制
- 指针与引用区别
- TCP包防粘连的读取方法
- 【Hive】Hive编程指南(Part 2)
- 面向对象5