5

この XML の例を使用します。

<A>
  <B>
    <id>0</id>
  </B>
  <B>
    <id>1</id>
  </B>
</A>

ノード B の XML ブロックを抽出し、XML 文字列を返す単純なメソッドが必要です。

<B>
  <id>1</id>
</B>

このノードを取得するには、XOM や Java XPath などの Java XPath ライブラリを使用する必要がありますが、完全な XML 文字列を取得する方法が見つかりませんでした。

C# を使用して 2 つの同等の回答済みの質問を見つけました: C# How to extract complete xml node set and how can I extract an XML block from an XML document?

4

2 に答える 2

29

lwburkのソリューションに加えて、DOMノードを文字列形式に変換するには、Transformerを使用できます。

private static String nodeToString(Node node)
throws TransformerException
{
    StringWriter buf = new StringWriter();
    Transformer xform = TransformerFactory.newInstance().newTransformer();
    xform.setOutputProperty(OutputKeys.OMIT_XML_DECLARATION, "yes");
    xform.transform(new DOMSource(node), new StreamResult(buf));
    return(buf.toString());
}

完全な例:

public static void main(String... args)
throws Exception
{
    String xml = "<A><B><id>0</id></B><B><id>1</id></B></A>";
    DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
    Document doc = dbf.newDocumentBuilder().parse(new InputSource(new StringReader(xml)));

    XPath xPath = XPathFactory.newInstance().newXPath();
    Node result = (Node)xPath.evaluate("A/B[id = '1']", doc, XPathConstants.NODE);

    System.out.println(nodeToString(result));
}

private static String nodeToString(Node node)
throws TransformerException
{
    StringWriter buf = new StringWriter();
    Transformer xform = TransformerFactory.newInstance().newTransformer();
    xform.setOutputProperty(OutputKeys.OMIT_XML_DECLARATION, "yes");
    xform.transform(new DOMSource(node), new StreamResult(buf));
    return(buf.toString());
}
于 2012-01-23T23:16:52.177 に答える
5

その 2 番目のB要素を参照するために必要な式は、次のようになります。

/*/B[id='1']

または、ターゲット ノードがドキュメント内の不明な位置にある場合は、次を使用します。

//B[id='1']

完全な Java の例 (XML が というファイルにあると仮定workbook.xml):

DocumentBuilderFactory domFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = domFactory.newDocumentBuilder();
Document doc = builder.parse("workbook.xml");
XPath xpath = XPathFactory.newInstance().newXPath();
XPathExpression expr = xpath.compile("//B[id='1']");        

NodeList nodes = (NodeList) expr.evaluate(doc, XPathConstants.NODESET);
for (int i = 0; i < nodes.getLength(); i++) {
    System.out.println("[" + nodes.item(i) + "]");
}
于 2012-01-23T23:10:38.017 に答える