XPathを使用して解析する以下のXMLがあります。
<?xml version="1.0" encoding="UTF-8"?>
<schema>
<element name="name_ele1" id="name_id_1" >test name1</element>
<element name="name_ele2" id="name_id_2" >test name2</element>
<element name="name_ele2" id="name_id_3" >test name3</element>
</schema>
渡したIDに基づいてxmlドキュメントから「名前」をフェッチしたいのですが、クエリが空白を返す代わりに必要なデータを取得できません。
XPathExpression expr = xpath.compile("/schema/element[@id='name_id_2']/name/text()");
このような:
XPathExpression expr = xpath.compile("/schema/element[@id='name_id_2']/@name");
式は、name
属性の値ではなく、name
要素内のテキストを選択しようとします。
import Java.io.File;
import Java.io.FileInputStream;
import Java.io.IOException;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.xpath.XPath;
import javax.xml.xpath.XPathConstants;
import javax.xml.xpath.XPathExpressionException;
import javax.xml.xpath.XPathFactory;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.xml.sax.SAXException;
public class XMLXpathReadder {
public static void main(String[] args) throws SAXException, IOException, ParserConfigurationException, XPathExpressionException {
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
DocumentBuilder db = dbf.newDocumentBuilder();
Document document = db.parse(new FileInputStream(new File("C:\\Test.xml")));// same xml comments as above.
XPathFactory xpf = XPathFactory.newInstance();
XPath xpath = xpf.newXPath();
Element userElement = (Element) xpath.evaluate("/schema/element", document,
XPathConstants.NODE);
System.out.println(userElement.getAttribute("id"));
System.out.println(userElement.getAttribute("name"));
}
}
上記のコードは私のために働きます。
しかし、すべての要素の値を読み取る方法。常に最初の要素ノードのみを取得しています。
<?xml version="1.0" encoding="UTF-8"?>
<schema>
<element name="name_ele1" id="_1" >test name1</element>
<element name="name_ele2" id="_2" >test name2</element>
<element name="name_ele2" id="_3" >test name3</element>
</schema>