Java Как извлечь полный блок XML
Используя этот пример XML:
<A>
<B>
<id>0</id>
</B>
<B>
<id>1</id>
</B>
</A>
Я хочу простой метод для извлечения блока XML узла B, возвращая строку XML:
<B>
<id>1</id>
</B>
Чтобы получить этот узел, я должен использовать библиотеку Java XPath, такую как XOM или Java XPath, но я не смог найти, как получить полную строку XML.
Я нашел два равноценных ответа на вопросы с использованием C#: C# Как извлечь полный набор узлов XML и как я могу извлечь блок XML из документа XML?
2 ответа
В дополнение к решению 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());
}
Выражение необходимо ссылаться на эту секунду 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) + "]");
}