ホームページ >类库下载 >java类库 >Java で xpath を使用して XML を解析する

Java で xpath を使用して XML を解析する

高洛峰
高洛峰オリジナル
2016-10-09 16:36:191725ブラウズ

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
この記事ではJavaでxpath操作を使ってxmlを操作する方法を主に紹介しています。
1) まず、dom4j で xpath 技術を使用する方法です
xPath でサポートされている jar パッケージをインポートします。 jaxen-1.1-beta-6.jar (最初に dom4j パッケージをインポートします。dom4j ダウンロード アドレス: http://www.dom4j.org/dom4j-1.6.1/)。

Java で xpath を使用して XML を解析する

パッケージをインポートした後の図に示すように:

Java で xpath を使用して XML を解析する



パッケージのインポート方法がわからない場合は、以前のブログを参照してください: Java の取得の概要XML ノードと XML ドキュメントの読み取りノード
2) Java で xpath メソッドを使用するには、主に 2 つのポイントがあります。ノード オブジェクト
以下では、その使用方法を説明するために例を使用します。
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 までご連絡ください。