>类库下载 >java类库 >xpath를 사용하여 Java에서 xml 구문 분석

xpath를 사용하여 Java에서 xml 구문 분석

高洛峰
高洛峰원래의
2016-10-09 16:36:191728검색

xpath는 xml 문서에서 정보를 찾는 언어입니다. xpath는 XML 문서의 요소와 속성을 탐색하는 데 사용됩니다. 반환 값은 노드, 노드 컬렉션, 텍스트, 노드와 텍스트의 혼합 등일 수 있습니다.
이 문서를 연구하기 전에 XML 노드, 요소, 속성, 텍스트, 처리 지침, 주석, 루트 노드, 네임스페이스, 노드 관계는 물론 xpath에 대해 어느 정도 이해하고 있어야 합니다.
XML 학습 주소: http://www.runoob.com/xml/xml-tutorial.html
XPath 기본 구문 학습 주소: http://www.runoob.com/xpath/xpath-tutorial.html
xpath 공식 문서: https://yunpan.cn/cvc4tEIGy5EvS 액세스 비밀번호 9d16
이 기사에서는 주로 xpath 작업을 사용하여 Java에서 xml을 작동하는 방법을 소개합니다.
1) 먼저 dom4j에서 xpath 기술을 사용하는 방법
xPath가 지원하는 jar 패키지를 가져옵니다. jaxen-1.1-beta-6.jar(먼저 dom4j 패키지를 가져옵니다. dom4j 다운로드 주소: http://www.dom4j.org/dom4j-1.6.1/).

xpath를 사용하여 Java에서 xml 구문 분석

패키지를 안내한 후 사진과 같이

xpath를 사용하여 Java에서 xml 구문 분석



패키지를 import하는 방법을 모르신다면 제 이전 블로그를 참고해주세요: Java에서 xml 노드 가져오기 및 xml 문서 노드 읽기 요약
2) 두 가지가 있습니다 Java Point에서 xpath 메소드를 사용하는 주요 방법:
List selectNodes("xpath 표현식"); 다중 노드 객체 쿼리
노드 selectSingleNode("xpath 표현식")
다음 예제를 사용하여 사용법을 설명합니다.

1. selectNodes 사용 방법:

package com.vastsum.demo;

import java.io.File;
import java.io.FileOutputStream;
import java.util.List;

import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;

/**
 * 
 * @author shutu008
 *selectNode的使用方法
 */
public class xpathDemo {

    public static void main(String[] args) throws Exception {

    Document doc = new SAXReader().read(new File("./src/contact.xml"));
        
        /**
         * @param xpath 表示xpath语法变量
         */
    String xpath="";
        
        /**
         * 1.      /      绝对路径      表示从xml的根位置开始或子元素(一个层次结构)
         */
        xpath = "/contactList";
        xpath = "/contactList/contact";
        
        /**
         * 2. //     相对路径       表示不分任何层次结构的选择元素。
         */
        xpath = "//contact/name";
        xpath = "//name";
        
        /**
         * 3. *      通配符         表示匹配所有元素
         */
        xpath = "/contactList/*"; //根标签contactList下的所有子标签
        xpath = "/contactList//*";//根标签contactList下的所有标签(不分层次结构)
        
        /**
         * 4. []      条件           表示选择什么条件下的元素
         */
        //带有id属性的contact标签
        xpath = "//contact[@id]";
        //第二个的contact标签
        xpath = "//contact[2]";
        //选择最后一个contact标签
        xpath = "//contact[last()]";
        
        /**
         * 5. @     属性            表示选择属性节点
         */
        xpath = "//@id"; //选择id属性节点对象,返回的是Attribute对象
        xpath = "//contact[not(@id)]";//选择不包含id属性的contact标签节点
        xpath = "//contact[@id='002']";//选择id属性值为002的contact标签
        xpath = "//contact[@id='001' and @name='eric']";//选择id属性值为001,且name属性为eric的contact标签
        
        /**
         *6.  text()   表示选择文本内容
         */
        //选择name标签下的文本内容,返回Text对象
        xpath = "//name/text()";
        xpath = "//contact/name[text()='张三']";//选择姓名为张三的name标签
        
        
        List<Node> list = doc.selectNodes(xpath);
        for (Node node : list) {
            System.out.println(node);
        }
    
        //写出xml文件
        //输出位置
        FileOutputStream out = new FileOutputStream("d:/contact.xml");
        
        //指定格式
        OutputFormat format = OutputFormat.createPrettyPrint();
        format.setEncoding("utf-8");
        XMLWriter writer = new XMLWriter(out,format);
        
        //写出内容
        writer.write(doc);
        
        //关闭资源
        writer.close();
        
    }
    

}

2. selectSingleNode 사용 방법

package com.vastsum.demo;

import java.io.File;
import java.util.Iterator;

import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;

/**
 * 
 * @author shutu008
 *selectSingleNode的使用
 */
 public class xpathDemo1{
     public static void main(String[] args) throws Exception{
         //读取XML文件,获得document对象
        SAXReader saxReader = new SAXReader();    
        Document doc = saxReader.read(new File("./src/contact.xml"));
        
        //使用xpath获取某个节点
        String xpath = "";
        
        //对contact元素 id="001"的节点,操作
        xpath = "//contact[@id = &#39;001&#39;]";
        Element contactElem =    (Element)doc.selectSingleNode(xpath);
        
        //设置这个节点的属性值
        contactElem.addAttribute("name", "001");
        
        //输出这个节点的所有属性值
        for(Iterator it = contactElem.attributeIterator();it.hasNext();){
        Attribute conAttr = (Attribute)it.next();
        String conTxt = conAttr.getValue();
        String conAttrName = conAttr.getName();
        System.out.println(conAttrName+" = "+conTxt);
        }
        
     }
 }


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.