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


查看14道真题和解析