Java实现解析并生成xml原理实例详解
程序员文章站
2022-06-03 15:07:50
xml解析: * 解析xml可以做: * 如果xml作为配置文件:读取 * 如果xml作为传输文件:写,读 xml解析思想: * dom:将文档加载进内存,形成一颗dom树(docume...
xml解析:
- * 解析xml可以做:
- * 如果xml作为配置文件:读取
- * 如果xml作为传输文件:写,读
xml解析思想:
- * dom:将文档加载进内存,形成一颗dom树(document对象),将文档的各个组成部分封装为一些对象。
- * 优点:因为,在内存中会形成dom树,可以对dom树进行增删改查。
- * 缺点:dom树非常占内存,解析速度慢。
document
element
text
attribute
comment
* sax:逐行读取,基于事件驱动
* 优点:不占内存,速度快
* 缺点:只能读取,不能回写
xml常用的解析器:
- * jaxp:sun公司提供的解析。支持dom和sax。(不常用)
- * jdom:
- * dom4j:dom for java民间方式,但是是事实方式。非常好。 支持dom
1.导入jar包 dom4j.jar
2.创建解析器
saxreader reader = new saxreader();
3.解析xml 获得document对象
document document = reader.read(url);
- * xpath:专门用于查询
- * 定义了一种规则。
- * 使用的方法:
- * selectsinglenode():
- * selectnodes():
使用步骤:
1、注意:要导包 jaxen...jar
2、创建解析器
saxreader reader = new saxreader();
3、解析xml 获得document对象
document document = reader.read(url);
* 解析xml:
// 1、得到某个具体的节点内容:第2本书的书名--》葵花宝典
// 2、遍历所有元素节点
xpath:
- // nodename 选取此节点。
- // / 从根节点选取。
- // // 从匹配选择的当前节点选择文档中的节点,而不考虑它们的位置。
- // .. 选取当前节点的父节点。
- // @ 选取属性。
- // [@属性名] 属性过滤
- // [标签名] 子元素过滤
例子:
/* demo.xml <?xml version="1.0" encoding="utf-8"?> <books> <book name="harry potter"> <author>j.k. rowling</author> <price>29.90$</price> </book> <book name="冰与火之歌"> <author>马丁</author> <price>28.90$</price> </book> </books> */ @test public void test1() throws documentexception{ saxreader reader = new saxreader(); document doc = reader.read("./src/demo.xml"); element root = doc.getrootelement(); element book1 = root.element("book"); system.out.println(book1.getpath()); system.out.println(book1.elementtext("price")); list<?> list = root.elements("book"); element book2 = (element) list.get(1); system.out.println(book2.attributevalue("name")); for(iterator<?> it = book1.elementiterator();it.hasnext() ; ){ element ele = (element) it.next(); system.out.println(ele.getname()+" : "+ele.gettext()); } } @test public void test2() throws exception{//使用 xpath,只用于快速查询,需要用jaxen...jar包 saxreader reader = new saxreader(); document doc = reader.read(new file("src/demo.xml")); node node = doc.selectsinglenode("/books/book[2]/author");//需要jaxen.jar包 string s = node.gettext(); system.out.println(s); node = doc.selectsinglenode("/books/book[2]/@name"); s = node.gettext(); system.out.println(s); list<node> booknames = doc.selectnodes("/books//@name"); for (node node1 : booknames) { system.out.println(node1.gettext()); } list<?> nodes = doc.selectnodes("/books/*/*"); for (int i=0; i<nodes.size(); ++i){ node node1 = (node) nodes.get(i); system.out.println(node1.getname() + ": " + node1.gettext()); } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。