Java Dom解析的两个实例

概述

Dom解析的文章已经烂大街了。在这里,只举两个场景下如何编码的例子:

xml内有多个同名节点,获取这多个同名节点
已获取到某个节点,生成这个节点的xml描述
详细的讲解看官请自行百度。
dom4j包下载链接为:点击下载dom4j

获取多个同名节点

xml实例

<model name="model" >
        <operator name="kafkaInput">
		<parameter  name="inputTopicName"  value="department1_tn1" />
	</operator>
	<operator name="addFielduuid">
		<parameter  name="parameter1" value="p1" />
	</operator>
	<operator name="kafkaOutput">
		<parameter  name="outTopicName" value="department1_tn1" />
	</operator>
	<connect from="kafkaInput.outport1" to="addFielduuid.inport1" />
	<connect from="addFielduuid.outport1" to="kafkaOutput.inport1" />
   </model>
如上xml实例中,model下有3个operator节点
获取多个同名节点不仅需要dom4j包,还需要Jaxen包。
Jaxen包下载链接为:点击下载Jaxen
获取这三个节点的代码为:

public static void parsingSameNameNode(String xmlPath) {
    File file = new File(argsPath);
	// 创建saxReader对象
	SAXReader reader = new SAXReader();
	// 通过read方法读取一个文件 转换成Document对象
	Document document;
	try {
		document = reader.read(file);
		List<Element> operators = document.selectNodes("/model/operator");
        for(Element operator:operators){
            //do something...
        }
	} catch (DocumentException e) {
		e.printStackTrace();
	}
}
通过接口selectNodes(String arg0)
接口参数为:"/model/operator"。意思是:获取model节点下所有的operator节点。Element可以理解为节点的信息
注意解析前读取xml内容、构建Document实例的代码:

File file = new File(argsPath);
// 创建saxReader对象
SAXReader reader = new SAXReader();
// 通过read方法读取一个文件 转换成Document对象
Document document;
try {
	document = reader.read(file);
    //do something...
} catch (DocumentException e) {
	e.printStackTrace();
}
节点的xml描述

dom解析得到某节点,将节点转为String,即节点的xml描述。
将节点转化为String格式,接口为asXML()。
转换代码如下:

// 获取根节点元素对象
Element rootNode = document.getRootElement();
// 获取context节点所有文字内容
String context = rootNode.element("context").asXML();
上面代码逻辑为:

根据document拿到dom树的根节点rooNode
获取rootNode节点下的context节点
使用asXML()接口,将节点转化为String格式。

转自cnblogs
全部评论

相关推荐

我即大橘:耐泡王
点赞 评论 收藏
分享
美团 后端开发 总包n(15%是股票)
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务