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" />
        <ouput path="/home" />
    </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格式。

修改属性值

  • 有两种修改属性值的方法
    • 先获取到该属性,使用属性的接口setValue(),修改属性值
    • 先获取到该属性所在节点,使用接口setAttributeValue()修改属性值

使用属性的setValue()接口,修改属性值

  • 代码逻辑为:
    • 获取到该属性所在节点
    • 获取该节点的属性,即要修改值的属性
    • 属性对象调用接口setValue(),接口参数为:属性值
    • 例上面xml中,output节点的path属性值修改为:/home/BYRans,代码如下:

      Element rootNode = document.getRootElement();
      Element node = rootNode.element("/model/output");
      Attribute path = node.attribute("path");
      path.setValue("/home/BYRans");

使用节点的setAttributeValue接口,修改属性值

  • 代码逻辑为:
    • 获取到该属性所在节点
    • 节点对象调用接口使用节点的setAttributeValue(),接口参数为:属性名和属性值
    • 注意此接口已不推荐使用,setAttributeValue()
    • 例上面xml中,output节点的path属性值修改为:/home/BYRans,代码如下:

      Element rootNode = document.getRootElement();
      Element node = rootNode.element("/model/output");
      node.setAttributeValue("path","/home/BYRans");

你可能感兴趣的:(Java Dom解析的三个实例)