Java获取XML节点总结之读取XML文档节点的方法
程序员文章站
2024-03-13 10:13:45
dom4j是java的xml api,用来读写xml文件的。目前有很多场景中使用dom4j来读写xml的。
要使用dom4j开发,需要下载导入dom4j相应的jar文件。...
dom4j是java的xml api,用来读写xml文件的。目前有很多场景中使用dom4j来读写xml的。
要使用dom4j开发,需要下载导入dom4j相应的jar文件。
官网下载:http://www.dom4j.org/dom4j-1.6.1/
github下载:http://dom4j.github.io/
下载解压之后如图所示:
我们只需要把dom4j-1.6.1.jar文件构建到我们开发项目中就可以了。
下面就以eclipse创建java项目的构建方法为例说明:
声明:本java项目的开发环境jdk1.8,eclipse版本 neon.1 release (4.6.1)
首先创建一个demo项目:
在demo项目中创建一个lib文件,把dom4j-1.6.1.jar文件拷贝到lib中,然后右键dom4j-1.6.1jar文件。如图所示:
点击add to bulid path即可构建到项目中去了。
导入成功如图所示:
在项目开发的过程中可以参考docs文件夹的(帮助文档),找到index.html打开,点击quick start可以通过帮助文档进行学习 dom4j进行xml的解析。
如图所示:
下面我将以详细例子去介绍java操作xml文件,文件名为exmple.java。
package vastsum; import java.io.file; import java.util.iterator; import java.util.list; import org.dom4j.document; import org.dom4j.documentexception; import org.dom4j.element; import org.dom4j.node; import org.dom4j.io.saxreader; /** * 读取下xml文档,获得document对象。 * 本文为xml连载第一篇,以下代码可以直接运行,结尾附上源码下载地址。 */ class exmple { public static void main(string[] args) throws documentexception { saxreader reader = new saxreader(); document document = reader.read(new file("./src/contact.xml")); /** * 节点对象的操作方法 */ //获取文档根节点 element root = document.getrootelement(); //输出根标签的名字 system.out.println(root.getname()); //获取根节点下面的所有子节点(不包过子节点的子节点) list<element> list = root.elements() ; //遍历list的方法 for (element e:list){ system.out.println(e.getname()); } //获得指定节点下面的子节点 element contactelem = root.element("contact");//首先要知道自己要操作的节点。 list<element> contactlist = contactelem.elements(); for (element e:contactlist){ system.out.println(e.getname()); } //调用下面获取子节点的递归函数。 getchildnodes(root); //获得当前标签下指定名称的第一个子标签 element conelem = root.element("contact"); system.out.println(conelem.getname()); //获得更深层次的标签(一层一层的获取) element nameelem = root.element("contact").element("name"); system.out.println(nameelem.getname()); } //递归查询节点函数,输出节点名称 private static void getchildnodes(element elem){ system.out.println(elem.getname()); iterator<node> it= elem.nodeiterator(); while (it.hasnext()){ node node = it.next(); if (node instanceof element){ element e1 = (element)node; getchildnodes(e1); } } } }
下面是对应的xml文件,文件名为contact.xml:
<?xml version="1.0" encoding="utf-8"?> <contactlist> <contact id="001" class="style"> <name>张三</name> <age>20</age> <phone>134222223333</phone> <email>zhangsan@qq.com</email> <qq>432221111</qq> </contact> <contact id="002"> <name>李四</name> <age>20</age> <phone>134222225555</phone> <email>lisi@qq.com</email> <qq>432222222</qq> </contact> <contacttwo> <name>王五</name> <age>32</age> <phone>465431341</phone> <emali>af@qq.com</emali> <qq>46164694</qq> </contacttwo> <test>测试</test> <test>其他用途</test> </contactlist>
两个文件的目录如题所示:
以上就是小编为大家带来的java获取xml节点总结之读取xml文档节点的方法全部内容了,希望大家多多支持~