Android DOM解析XML示例程序
DOM方式解析xml是先把xml文档都读到内存中,然后再用DOM API来访问树形结构,并获取数据的。DOM比较符合人的思维模式,但是其对内存的消耗比较大。
activity_main.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical"
tools:context=".MainActivity" > <TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:id="@+id/textview01" /> </LinearLayout>
在assets目录下添加product.xml文件
<?xml version="1.0" encoding="UTF-8"?>
<products>
<product name="黑茶" length="115">
<introducton>
因产自中国湖南安化县而得名。是中国古代名茶之一,上个世纪50年代曾一度绝产,以至于默默无名。2010年,湖南黑茶走进中国上海世博会,成为中国世博会十大名茶之一。安化黑茶再度走进茶人的视野,成为茶人的新宠。其特色的千两茶,堪称一绝。<br/>
</introducton>
<imageurl>
http://baike.baidu.com/view/2255732.htm
</imageurl>
</product>
<product name="擂茶" length="109">
<introducton>
起于汉、盛于明清的地方擂茶至今在湖南中部以北的安化一带传袭。其色味、功效、制作方法,以及饮茶习俗等,无不让途经于此的人感受到山乡古朴浓郁的擂茶文化。春暖花开的四月,记者跟随“环行洞庭湖”采访团走进了这个擂茶飘香的地方。<br/>
</introducton>
<imageurl>
http://baike.baidu.com/view/66985.htm
</imageurl>
</product>
</products>
创建Product类
/**
*
*/
package com.hyzhou.domxml2; import java.io.Serializable; /**
* @author hyzhou
*
* 2013-8-29
*/
public class Product implements Serializable { /**
*
*/
private static final long serialVersionUID = -6907670870626810002L;
private int length;
private String introducton;
private String imageurl;
private String name;
public int getLength() {
return length;
}
public void setLength(int length) {
this.length = length;
}
public String getIntroducton() {
return introducton;
}
public void setIntroducton(String introducton) {
this.introducton = introducton;
}
public String getImageurl() {
return imageurl;
}
public void setImageurl(String imageurl) {
this.imageurl = imageurl;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
} }
创建MainActivity类,用于解析XML并显示结果
package com.hyzhou.domxml2; import java.io.InputStream;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List; import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory; import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NodeList; import android.os.Bundle;
import android.util.Log;
import android.widget.TextView;
import android.app.Activity; public class MainActivity extends Activity {
private TextView textView ;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
textView=(TextView)findViewById(R.id.textview01);
StringBuffer sb=new StringBuffer();
ArrayList<Product> list= (ArrayList<Product>) getProductFromXml("product.xml");
Iterator<Product> it=list.iterator();
while(it.hasNext())
{
Product myit=it.next();
sb.append(myit.getName()+" 长度:"+myit.getLength()+"\n"+myit.getImageurl() +"\n"+myit.getIntroducton()+"\n\n");
}
Log.i("wa~~~~~",sb.toString());
textView.setText(sb.toString());
}
public List<Product> getProductFromXml(String fileName)
{
List<Product> products=new ArrayList<Product>();
DocumentBuilderFactory factory=null;
DocumentBuilder builder=null;
Document document=null;
InputStream inputStream=null;
//创建实例DocumentBuilderFactory
factory=DocumentBuilderFactory.newInstance();
try {
//创建DocumentBuilder
builder=factory.newDocumentBuilder();
//获取输入流
inputStream=this.getResources().getAssets().open(fileName);
Log.i("inputStream", inputStream.toString());
//加载XML文档
document=builder.parse(inputStream);
//找到根元素
Element root=document.getDocumentElement();
NodeList nodes=root.getElementsByTagName("product"); //遍历所有子结点
Product myproduct=null;
for(int i=0;i<nodes.getLength();i++)
{
myproduct =new Product();
//得到第一个根节点product
Element productElement=(Element) nodes.item(i);
//获取根节点的属性name和length
myproduct.setName(productElement.getAttribute("name"));
myproduct.setLength(Integer.parseInt(productElement.getAttribute("length")));
//获取子节点imageulr和introduction
Element introduction =(Element) productElement.getElementsByTagName("introducton").item(0);
myproduct.setIntroducton(introduction.getTextContent().trim());
Element imageurl=(Element) productElement.getElementsByTagName("imageurl").item(0);
myproduct.setImageurl(imageurl.getTextContent().trim());
//把得到的元素加入到List里面
products.add(myproduct);
}
inputStream.close();
} catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
}
return products; } }
参考文档:http://www.cnblogs.com/zhangdongzi/archive/2011/04/14/2016434.html
Android DOM解析XML示例程序的更多相关文章
- Android DOM解析XML方法及优化
在Android应用开发中,我们常常要在应用启动后从服务器下载一些配置文件,这些配置文件包含一些项目中可能用到的资源,这些文件很多情况下是XML文件,这时就要将XML下载到文件中保存,之后再解析XML ...
- android DOM解析Xml
文章转自:http://blog.sina.com.cn/s/blog_a661f16c0101d5qp.html People类是自己写的一个类,主要保存各个字符串数据. 由于没学过Xml语法只 ...
- Android之DOM解析XML
一.DOM解析方法介绍 DOM是基于树形结构的节点或信息片段的集合,允许开发人员使用DOM API遍历XML树,检索所需数据.分析该结构通常需要加载整个文档和构造树形结构,然后才可以检索和更新节点信息 ...
- Java从零开始学四十二(DOM解析XML)
一.DOM解析XML xml文件 favorite.xml <?xml version="1.0" encoding="UTF-8" standalone ...
- xml语法、DTD约束xml、Schema约束xml、DOM解析xml
今日大纲 1.什么是xml.xml的作用 2.xml的语法 3.DTD约束xml 4.Schema约束xml 5.DOM解析xml 1.什么是xml.xml的作用 1.1.xml介绍 在前面学习的ht ...
- Java解析XML文档(简单实例)——dom解析xml
一.前言 用Java解析XML文档,最常用的有两种方法:使用基于事件的XML简单API(Simple API for XML)称为SAX和基于树和节点的文档对象模型(Document Object ...
- [置顶] Android学习系列-Android中解析xml(7)
Android学习系列-Android中解析xml(7) 一,概述 1,一个是DOM,它是生成一个树,有了树以后你搜索.查找都可以做. 2,另一种是基于流的,就是解析器从头到尾解析一遍xml文件. ...
- Android中解析XML格式数据的方法
XML介绍:Extensible Markup Language,即可扩展标记语言 一.概述 Android中解析XML格式数据大致有三种方法: SAX DOM PULL 二.详解 2.1 SAX S ...
- Java解析XML文档——dom解析xml
一.前言 用Java解析XML文档,最常用的有两种方法:使用基于事件的XML简单API(Simple API for XML)称为SAX和基于树和节点的文档对象模型(Document Object M ...
随机推荐
- 新浪微博5s钟后跳转页面
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...
- C++构造函数的调用
C++中类的构造函数的调用有四种形式 C++中对象的实例化有四种情况: 1.调用默认构造函数. 2.隐式调用构造函数 3.显示调用构造函数 4.使用new操作符 如图所示,前三种在对象的作用域之外就会 ...
- Linux下crontab内环境变量与Shell环境变量的关系【转】
crontab,总是不会缺省的从用户profile文件中读取环境变量参数 经常导致在手工执行某个脚本时是成功的,但是到crontab中试图执行时就会报错. 解决办法如下: 方法一:在shell文件中获 ...
- python 将txt内容写入excel
#!/usr/bin/env python # -*- coding: utf-8 -* import os import xlrd import xlwt import datetime impor ...
- java web 应用中包,接口的设计
采用标准的架构:描述从低层到高层首先是系统分析,找出你需要什么功能,然后按照下面的步骤执行: 数据库层:数据库层就是SQL语句.数据库.表.视图.触发器等等的创建和管理.这一层和JAVA无关,但是却是 ...
- pku oj overhang叠加卡片求最少的卡片数
这个估计是里面第二简单的了,因为第一简单的是求a+b 哈哈,一submit就ac了 题目如下: Description How far can you make a stack of cards ov ...
- linux下tree命令详解
linux下tree命令详解linux下的tree就比较强大了,但一般系统并不自带这个命令,需要手动下载安装:sudo apt-get install tree .文件很小,只有31K,但功能可强大了 ...
- jffs2系统制作2
http://blog.chinaunix.net/uid-23208702-id-353022.html 1.2. 安装zlib库 由于交叉编译mtd工具时需要zlib.h文件,所以在编译之前先 ...
- fancybox 使用方法
项目中需要做一个相册功能.选择的是fancybox,大概记录一下使用方法: 1.引用fancybox所需要的文件,你可以下载至本地或者引用CDN. fancybox最新版本下载地址:http://fa ...
- JavaScript裸体识别技术
当第一次听说nude.js的时候,我非常怀疑这种浏览器端的裸体识别技术,有几个理由: 正常情况下,裸体识别应该在服务器端进行,这样,那些色情图片或色情视频才能在发送给浏览者前被发现. 我不相信完全依赖 ...