这篇文章主要讲解了Java如何实现解析并生成xml,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。
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());
}
}
看完上述内容,是不是对Java如何实现解析并生成xml有进一步的了解,如果还想学习更多内容,欢迎关注天达云行业资讯频道。