Java Tips – DOM – XPathを指定して属性の値を取得するには


DOM(Document Object Model)を使用して、XPathを指定して属性の値を取得する手順は以下の通りです。

  1. XPathFactoryクラス、XPathクラスを使用して、XPathを作成します。
  2. XPathクラスのevaluateメソッドで、XPathを指定して属性の値を取得します。

パース処理するXMLドキュメントは以下の通りです。

<?xml version="1.0" encoding="UTF-8"?>
<root>
  <child1 attr1="要素1の属性1" attr2="要素1の属性2">要素1</child1>
  <child2 attr1="要素2の属性1" attr2="要素2の属性2">要素2</child2>
  <child3 attr1="要素3の属性1" attr2="要素3の属性2">要素3</child3>
</root>

package net.tk_factory.example.xml.dom;

import java.io.IOException;

import javax.xml.xpath.XPath;
import javax.xml.xpath.XPathExpressionException;
import javax.xml.xpath.XPathFactory;

import org.apache.log4j.Logger;
import org.apache.xerces.parsers.DOMParser;
import org.w3c.dom.Document;
import org.xml.sax.SAXException;

import net.tk_factory.example.AbstractExample;

/**
 * DOM(Document Object Model)を使用したサンプルプログラムです。<br/>
 * <br/>
 * <b>内容</b>
 * <ol type="1">
 * <li>XPathを指定して属性の値を取得します。</li>
 * </ol>
 *
 * @author Takafumi Kondo (TK Factory)
 */
public class ExampleGetValueOfAttributeByXPath extends AbstractExample
{
    /** クラス名 */
    private static final String CLASS_NAME =
            ExampleGetValueOfAttributeByXPath.class.getSimpleName();

    /** ロガー */
    private static final Logger LOGGER =
            Logger.getLogger(ExampleGetValueOfAttributeByXPath.class.getName());

    /** 入力ファイル名 */
    private static final String IN_FILE_NAME =
            EXAMPLE_FILE_DIRECTORY + CLASS_NAME + ".xml";

    /**
     * ExampleGetValueOfAttributeByXPathオブジェクトを構築すると、
     * UnsupportedOperationExceptionがスローされます。<br/>
     */
    protected ExampleGetValueOfAttributeByXPath()
    {
        throw new UnsupportedOperationException();
    }

    /**
     * mainメソッドです。<br/>
     *
     * @param args 引数
     */
    public static void main(String[] args)
    {
        LOGGER.info("[START]" + CLASS_NAME);

        try
        {
            //パーサを生成する
            DOMParser parser = new DOMParser();

            //XMLファイルをパースする
            parser.parse(IN_FILE_NAME);

            //DOCUMENTノードを取得する
            Document document = parser.getDocument();

            //XPathを作成する
            XPathFactory xpfactory = XPathFactory.newInstance();
            XPath xpath = xpfactory.newXPath();

            //XPathを指定して属性の値を取得する
            String value1 = xpath.evaluate("/root/child1/@attr1", document);
            LOGGER.debug(value1);
            String value2 = xpath.evaluate("/root/child2/@attr2", document);
            LOGGER.debug(value2);
        }
        catch (SAXException ex)
        {
            //XMLファイルのパースに失敗した場合
            LOGGER.error(getStackTrace(ex));
        }
        catch (XPathExpressionException ex)
        {
            //XMLファイルのパースに失敗した場合
            LOGGER.error(getStackTrace(ex));
        }
        catch (IOException ex)
        {
            //入出力例外が発生した場合
            LOGGER.error(getStackTrace(ex));
        }

        LOGGER.info("[E N D]" + CLASS_NAME);
    }
}

上記のサンプルプログラムの実行結果は以下の通りです。

2010/04/29 22:41:06.801 [INFO ]:    0:[START]ExampleGetValueOfAttributeByXPath
2010/04/29 22:41:06.848 [DEBUG]:   47:要素1の属性1
2010/04/29 22:41:06.848 [DEBUG]:   47:要素2の属性2
2010/04/29 22:41:06.848 [INFO ]:   47:[E N D]ExampleGetValueOfAttributeByXPath

関連記事

  1. ソースを見直し、一部、修正しました。

  1. トラックバック 0

return top