XML && XML的解析
从技术流派上讲,XML解析
也分为:
1. DOM:
- 跟HTML类似,是整个将XML文件加载到内容中,然后映射为Java对象,进行解析。
- 弊端: 不适合处理大型的XML文件。
- 优势:保留了节点的信息,方便操作。
2. SAX
- 不是完整的加载整个XML文件,而是一边读,一边解析。
- 优势: 可以处理大型的XML文件
- 弊端: 它由于读取完成以后就丢弃信息,所以,无法操作XML文档,只能读取。
市面上能够解析XML的库有很多,包括Java语言自己的。
其中,最常见的是名为
dom4j
的一个库。
官网:
https://dom4j.github.io/
读取XML文档的案例
//1. 根据一个xml文档的 URL地址,解析出一个
Document
对象
//2. 根据document对象的getRootElement()
方法可以返回文档的根节点
//3. 根据Element对象的
elementIterator()
可以返回所有的子元素(迭代器)
elements()
返回子元素列表
element("name")
返回指定名称的唯一的子元素
elementIterator("foo")
返回所有自定标签名的子元素(迭代器)
elements("student")
返回指定名称的子元素列表
attributeIterator();
返回元素的所有属性(迭代器)
getNa