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