9

次のような構造の XML があります。

<category>
   <subCategoryList>
      <category>

      </category>
      <category>
         <!--and so on -->
      </category>
   </subCategoryList>
</category>

subcategoryリスト ( )を持つ Category クラスがありList<Category>ます。この XML ファイルを XPath で解析しようとしていますが、カテゴリの子カテゴリを取得できません。

XPathでこれを行うにはどうすればよいですか? これを行うより良い方法はありますか?

4

3 に答える 3

19

このリンクには、必要なものがすべて含まれています。要するに:

 public static void main(String[] args) 
   throws ParserConfigurationException, SAXException, 
          IOException, XPathExpressionException {

    DocumentBuilderFactory domFactory = 
    DocumentBuilderFactory.newInstance();
          domFactory.setNamespaceAware(true); 
    DocumentBuilder builder = domFactory.newDocumentBuilder();
    Document doc = builder.parse("persons.xml");
    XPath xpath = XPathFactory.newInstance().newXPath();
       // XPath Query for showing all nodes value
    XPathExpression expr = xpath.compile("//person/*/text()");

    Object result = expr.evaluate(doc, XPathConstants.NODESET);
    NodeList nodes = (NodeList) result;
    for (int i = 0; i < nodes.getLength(); i++) {
     System.out.println(nodes.item(i).getNodeValue()); 
    }
  }
于 2010-05-12T11:18:43.340 に答える
2

これの XPath 式は " //category/subCategoryList/category" になると思います。ルート ノードの子だけが必要な場合はcategory(それがドキュメント ルート ノードであると仮定して)、" /category/subCategoryList/category" を試してください。

于 2008-12-04T14:52:19.063 に答える
0

これはあなたのために働くでしょう:

NodeList nodes = (NodeList) xpath.evaluate("//category//subCategoryList/category",
inputSource, XPathConstants.NODESET);

次に、必要に応じてカテゴリの子を解析できます。

于 2008-12-04T14:52:37.143 に答える