微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

xml文件解析

xml文件解析

1.1 思路

1.1.1 使用jdom首先需要指定使用什么解析器

SAXBuilder builder=newSAXBuilder(false); 这表示使用的是认的解析器

1.1.2 得到document,我们以后要进行的操作都是对这个document操作的

Document doc=builder.build(xmlpath);

1.1.3 得到根元素

Element books=doc.getRootElement();

1.1.4 得到元素(节点)的(集合)

1) 如果子节点只有一个。注意:使用这个方法括号中的标签必须要有

ElementmsgTypeElement = (Element)XPath.selectSingleNode(mddi,"//msgType");

2)如果子节点有多个。注意:使用这个方法,括号中的标签可有可没有。

Listbooklist=books.getChildren("book");

//当有多个相同节点的时候

或者:List provinceList = XPath.selectNodes(mddi,"//sys-config/provinces-info/province");

这表示得到“books”元素的所在名称为“book”的元素,并把这些元素都放到一个List集合中

1.1.5 循环list集合

for (Iterator iter =booklist.iterator(); iter.hasNext();) {
Elementbook = (Element) iter.next();
}

还有一种轮循方法是:

for(inti=0;I<booklist.size();I++){
Elementbook=(Element)booklist.get(i);
}

1.1.6 取得元素的属性

Stringemail=book.getAttributeValue("email");

取得元素book属性名为“email”的属性值。

1.1.7 取得元素的子元素(为最低层元素)的值:

Stringname=book.getChildTextTrim("name");

注意的是,必须确定book元素的名为“name”的子元素只有一个

1.1.8改变元素(为最低层元素)的值:

book.getChild("name").setText("alterrjzjh");
这只是对Document修改,并没有在实际的XML文档中进行修改

1.1.9 保存Document修改到XML文件中:

XMLOutputter outputter=new XMLOutputter();

outputter.output(doc,newFileOutputStream(xmlpath));

原文地址:https://www.jb51.cc/xml/293994.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。