当前位置: 移动技术网 > IT编程>开发语言>Java > Java实现解析并生成xml原理实例详解

Java实现解析并生成xml原理实例详解

2020年06月14日  | 移动技术网IT编程  | 我要评论

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());
  }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网