12

この XML ファイルに対して XPath クエリを作成したいと考えています (抜粋を示します)。

<?xml version="1.0" encoding="UTF-8"?>
<!-- MetaDataAPI generated on: Friday, May 25, 2007 3:26:31 PM CEST -->
<Component xmlns="http://xml.sap.com/2002/10/metamodel/webdynpro" xmlns:IDX="urn:sap.com:WebDynpro.Component:2.0" mmRelease="6.30" mmVersion="2.0" mmTimestamp="1180099591892" name="MassimaleContr" package="com.bi.massimalecontr" masterLanguage="it">
...
    <Component.UsedModels>
        <Core.Reference package="com.test.test" name="MasterModel" type="Model"/>
        <Core.Reference package="com.test.massimalecontr" name="MassimaleModel" type="Model"/>
        <Core.Reference package="com.test.test" name="TravelModel" type="Model"/>
    </Component.UsedModels>
...

私はこのコードスニペットを使用しています:

DocumentBuilderFactory domFactory = DocumentBuilderFactory.newInstance();
domFactory.setNamespaceAware(true);
DocumentBuilder builder = domFactory.newDocumentBuilder();
Document document = builder.parse(new File("E:\\Test branch\\test.wdcomponent"));
XPathFactory factory = XPathFactory.newInstance();
XPath xpath = factory.newXPath();

xpath.setNamespaceContext(new NamespaceContext() {
...(omitted)

System.out.println(xpath.evaluate(
    "//d:Component/d:Component.UsedModels/d:Core.Reference/@name", 
    document));

私が期待しているもの:

MasterModel
MassimaleModel
TravelModel

私が得ているもの:

MasterModel

最初の要素だけが返されるようです。クエリに一致するすべてのオカレンスを取得するにはどうすればよいですか?

4

2 に答える 2

24

タイプのアイテムが手に入りますNodeList

XPathExpression expr = xpath.compile("//Core.Reference");
NodeList list= (NodeList) expr.evaluate(doc, XPathConstants.NODESET);
for (int i = 0; i < list.getLength(); i++) {
    Node node = list.item(i);
    System.out.println(node.getTextContent());
    // work with node
于 2012-05-24T09:41:53.470 に答える
4

Java で XPath を使用して XML を読み取る方法を参照してください。

その例に従って、最初に XPath 式をコンパイルしてから実行し、NodeSet を戻すように指定すると、必要な結果が得られるはずです。

于 2012-05-24T09:42:31.707 に答える