文章转自:http://blog.sina.com.cn/s/blog_a661f16c0101d5qp.html
People类是自己写的一个类,主要保存各个字符串数据。
由于没学过Xml语法只能依样画葫芦了呗- -
1.为了具有扩展性 自己编了一个xml文件:
<?xml version="1.0" encoding="utf-8"?>
<peoples>
<people
name="谢XX" age="23" >aaaaaaaaa
<nationality>中国 </nationality>
<graduation>XXX大学</graduation>
<introduction name="介绍">谢XX测试描述的句子长长。。。。。。 </introduction>
</people>
<people
name="王XX"age="23" >bbbbbbbb
<nationality>中国</nationality>
<graduation>XX大学</graduation>
<introduction>王XX测试描述的句子</introduction>
</people>
<people
name="林XX" age="23" >cccccccc
<nationality>中国</nationality>
<graduation>理工大学</graduation>
<introduction>林XX测试描述的句子</introduction>
</people>
</peoples>
总结:有点像是树形结构。
2.关键解析部分代码:
(1)声明各种需要的类:
DocumentBuilderFactory factory = null;
DocumentBuilder builder = null;
Document document = null;
InputStream inputStream = null;
(2)实现DOM解析
list = new ArrayList<People>();
factory = DocumentBuilderFactory.newInstance();
try {
//惯例 取得document文件实例的过程
builder = factory.newDocumentBuilder();
inputStream = XmlMainActivity.this.getResources()
.getAssets().open("test.xml");//以工程文件下assets文件夹为根目录
document = builder.parse(inputStream);
//取得根Element 以此列出所有节点NodeList
Element root = document.getDocumentElement();
//getElementsByTagName是在当前的Element 下查找"people"标志并生成NodeList
NodeList nodes = root.getElementsByTagName_r("people");
//取出每个节点中的数据,这里应该分成3种数据,
//①是name、age那样的Attribute数据;
//②是在<people>括号外的NodeValue数据;
//③最后是在其地下的另一个node数据节点。
for (int i = 0; i < nodes.getLength(); i++) {
Element peopleitem = (Element) nodes.item(i);
name = peopleitem.getAttribute("name");
age = peopleitem.getAttribute("age");
// introduction=peopleitem.getFirstChild().getNodeValue();
Element item = (Element) peopleitem
.getElementsByTagName_r("nationality").item(0);
nationality = item.getFirstChild().getNodeValue();
item = (Element) peopleitem.getElementsByTagName_r(
"graduation").item(0);
graduation = item.getFirstChild().getNodeValue();
item = (Element) peopleitem.getElementsByTagName_r(
"introduction").item(0);
introduction =item.getFirstChild().getNodeValue();
// NodeList childenodes=peopleitem.getElementsByTagName_r("introduction");
// Element childitem=(Element) childenodes.item(0);
// introduction=childitem.getAttribute("name");
// introduction=introduction+" "+childitem.getFirstChild().getNodeValue();
list.add(new People(name, age, nationality, graduation,
introduction, XmlMainActivity.this));
}
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
根据粗俗的理解:DOM解析过程有点像树遍历过程,
①取得根节点Element root =document.getDocumentElement();
②取得所有节点列表NodeList nodes = root.getElementsByTagName_r("people");
③取得第i个子节点Element peopleitem = (Element) nodes.item(i);
④取得第i个子节点的Attribute数据、NodeValue数据
⑤列出第i个子节点的"introduction"子节点NodeList childenodes=peopleitem.getElementsByTagName_r("introduction");
⑥重复③④步骤;
⑦列出第i个子节点的"nationality"子节点NodeList。
⑧重复③④步骤;
...
⑨取得根目录下第i+1个子节点Element peopleitem = (Element) nodes.item(i);
再重复
xml虽然复杂了点但是画下图还是很好搞的。
element和document继承Node接口
nodelist本身只是一个接口
document本身代表整个xml文件,element代表某个节点,其中由document.getDocumentElement()取得的element为根节点,
然后从根节点调用root.getElementsByTagName_r("people");可以取得不同标签下的所有Nodelist,
再取得(Element) nodelist.item(i);子节点
最后可以再再该子节点下调用getElementsByTagName。
整个解析过程可以不按照xml固有的层级关系,即可以直接从根节点下寻找第N层标签,只要逻辑上处理得当。(?木有验证)。
音乐路径:
java通过url如何获取网页上的xml文件:
String url = "..................";
URL connect = new URL(url.toString());
URLConnection connection = connect.openConnection();
connection.setDoOutput(true);
OutputStreamWriter paramout = new OutputStreamWriter(connection.getOutputStream());
paramout.write(param.toString());
paramout.flush();
BufferedReader reader = new BufferedReader(new InputStreamReader(connection.getInputStream(),"UTF-8"));
HttpClient也可以
- Android DOM解析XML方法及优化
在Android应用开发中,我们常常要在应用启动后从服务器下载一些配置文件,这些配置文件包含一些项目中可能用到的资源,这些文件很多情况下是XML文件,这时就要将XML下载到文件中保存,之后再解析XML ...
- Android DOM解析XML示例程序
DOM方式解析xml是先把xml文档都读到内存中,然后再用DOM API来访问树形结构,并获取数据的.DOM比较符合人的思维模式,但是其对内存的消耗比较大. activity_main.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 ...
- [置顶] 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 ...
- Dom 解析XML
xml文件 <?xml version="1.0" encoding="UTF-8"?><data> <book id=&q ...
- JAVA中使用DOM解析XML文件
XML是一种方便快捷高效的数据保存传输的格式,在JSON广泛使用之前,XML是服务器和客户端之间数据传输的主要方式.因此,需要使用各种方式,解析服务器传送过来的信息,以供使用者查看. JAVA作为一种 ...
- 简单谈谈dom解析xml和html
前言 文件对象模型(Document Object Model,简称DOM),是W3C组织推荐的处理可扩展标志语言的标准编程接口.html,xml都是基于这个模型构造的.这也是一个W3C推出的标准.j ...
随机推荐
- idea中不重启服务器更改代码(使用jrebel)
http://139.199.89.239:1008/88414687-3b91-4286-89ba-2dc813b107ce 第一步 第二步:下载jrebel 第三步(这里有些有有些没有) 下载完后 ...
- react(二):组件的通信
对于组件来说,通信无非两种,父子组件通信,和非父子组件通信 一.父子父子组件通信 1.父组件给子组件传值 对于父组件来说,props是他们之间的媒介 class Parent extends Comp ...
- 【Java】重载(Overload)与重写(Override)
方法的语法 修饰符 返回值类型 方法名(参数类型 参数名){ ... 方法体 ... return 返回值; } 重载(overload) /** * 重载Overload: * 同一个类中,多个方法 ...
- checkboxlist 如何配置数据源?
<f:CheckBoxList runat="server" ColumnNumber="4" ColumnVertical="true&quo ...
- A的B次幂
Description 给出两个正整数A和B 请输出A的B次幂 结果可能很大,请对1000000007求模 Input A和B,两个整数均不大于10^18 Output A的B次幂对100000000 ...
- MySQL主从复制读写分离如何提高从库性能-实战
在做主从读写分离时候,需要注意主从的一些不同参数设置,来提高从库的性能,提高应用读取数据的速度,这样做很有必要的. 做读写分离复制主从参数不同设置如下(需要根据自己应用实际情况来设置): parmet ...
- 常见Linux的发行版有哪些?并描述不同发行版之间的联系与区别。
一.按系列罗列linux的发行版,并描述不同发行版之间的联系和区别 Linux发行版=Linux内核+商业软件 linux的发行版: RedHat.Fedora.suse.红旗.debian.Ubun ...
- oracle之bitmap索引
oracle常见的索引是BTree索引和Bitmap索引. BTree索引特点: 默认索引 适合大量增删改查 不能用or操作符 适合高基数的列(即唯一值多) 创建sql:create index li ...
- php-5.6.26源代码 - 如何用C语言支持“类似异常”机制
代码编写在文件php-\Zend\zend.h #define zend_bailout() _zend_bailout(__FILE__, __LINE__) #ifdef HAVE_SIGSETJ ...
- Nginx 配置继承模型
要了解nginx的继承模型,首先需要知道nginx使用多个配置块进行操作.在nginx中,这样的块被称为上下文,例如,放置在服务器上下文中的配置指令驻留在server { }块中,就像放置在http上 ...