問題描述
首先,我必須說,我發現 Xpath
是一個非常好的解析器,并且在與其他解析器進行比較時,我認為它非常強大.
First, I must say that I find Xpath
as a very nice parser , and I guess pretty powerful when comparing it to other parsers .
給定以下代碼:
DocumentBuilderFactory domFactory =
DocumentBuilderFactory.newInstance();
domFactory.setNamespaceAware(true);
DocumentBuilder builder = domFactory.newDocumentBuilder();
Document doc = builder.parse("input.xml");
XPath xpath = XPathFactory.newInstance().newXPath();
如果我想找到第 1 輪的 first
節點 &1號門,這里:
If I wanted to find the first
node of Round 1 & Door 1 , here :
<Game>
<Round>
<roundNumber>1</roundNumber>
<Door>
<doorName>abd11</doorName>
<Value>
<xVal1>0</xVal1>
<xVal2>25</xVal2>
<pVal>0.31</pVal>
</Value>
<Value>
<xVal1>25</xVal1>
<xVal2>50</xVal2>
<pVal>0.04</pVal>
</Value>
<Value>
<xVal1>50</xVal1>
<xVal2>75</xVal2>
<pVal>0.19</pVal>
</Value>
<Value>
<xVal1>75</xVal1>
<xVal2>100</xVal2>
<pVal>0.46</pVal>
</Value>
</Door>
<Door>
<doorName>vvv1133</doorName>
<Value>
<xVal1>60</xVal1>
<xVal2>62</xVal2>
<pVal>1.0</pVal>
</Value>
</Door>
</Round>
<Round>
<roundNumber>2</roundNumber>
<Door>
<doorName>eee</doorName>
<Value>
<xVal1>0</xVal1>
<xVal2>-25</xVal2>
<pVal>0.31</pVal>
</Value>
<Value>
<xVal1>-25</xVal1>
<xVal2>-50</xVal2>
<pVal>0.04</pVal>
</Value>
<Value>
<xVal1>-50</xVal1>
<xVal2>-75</xVal2>
<pVal>0.19</pVal>
</Value>
<Value>
<xVal1>-75</xVal1>
<xVal2>-100</xVal2>
<pVal>0.46</pVal>
</Value>
</Door>
<Door>
<doorName>cc</doorName>
<Value>
<xVal1>-60</xVal1>
<xVal2>-62</xVal2>
<pVal>0.3</pVal>
</Value>
<Value>
<xVal1>-70</xVal1>
<xVal2>-78</xVal2>
<pVal>0.7</pVal>
</Value>
</Door>
</Round>
</Game>
我會這樣做的:
XPathExpression expr = xpath.compile("http://Round[1]/Door[1]/Value[1]/*/text()");
Object result = expr.evaluate(doc, XPathConstants.NODESET);
NodeList nodes = (NodeList) result;
如果我想要第 1 輪的 second
節點 &那么門1:
and if I wanted the second
node of Round 1 & Door 1 then :
XPathExpression expr = xpath.compile("http://Round[1]/Door[1]/Value[2]/*/text()");
但是我如何使用循環來做到這一點,因為我不知道我有多少 Value-nodes
,這意味著我如何使用循環來做到這一點,每次迭代我都會檢索 3(我的意思是 xVal1
、 xVal2
和 pVal
值)更多值節點的值!?
but how do I do this using a loop , since I don't know how much Value-nodes
I have , meaning how can I do this using a loop , where each iteration I retrieve 3 (I mean the xVal1
, xVal2
and pVal
values ) more values of a Value node !?
要求這樣做的原因是:
我不知道我有多少
Round
-s
我不知道我有多少Value
-s
我不想每次都聲明一個新的XPathExpression
I don't want to declare every time a new XPathExpression
謝謝.
推薦答案
選項 1 - 遍歷文檔中的所有 Value 元素.只需要一次評估,但很難知道該值屬于哪個圓形或門元素.
Option 1 - Iterate over all Value elements in the document. Only one evaluation required, but difficult to know which Round or Door element the Value belongs to.
NodeList result = (NodeList) xpath.evaluate("http://Round/Door/Value/*/text()", doc, XPathConstants.NODESET);
選項 2 - 分別迭代每個 Round、Door 和 Value 元素.需要更多評估,但上下文很容易知道.如果需要索引,很容易在循環中添加一個計數器.
Option 2 - Iterate over each Round, Door and Value elements separately. Requires more evaluations but the context is easily known. If index is required, it is easy to add a counter to the loops.
// Get all rounds and iterate over them
NodeList rounds = (NodeList) xpath.evaluate("http://Round", doc, XPathConstants.NODESET);
for (Node round : rounds) {
// Get all doors and iterate over them
NodeList doors = (NodeList) xpath.evaluate("Door", round, XPathConstants.NODESET);
for (Node door : doors) {
// Get all values and iterate over them
NodeList values = (NodeList) xpath.evaluate("Value/*/text()", door, XPathConstants.NODESET);
for (Node value : values) {
// Do something
}
}
}
選項 3 - 根據您的要求將上述方法組合起來
Option 3 - Do some combination of the above depending on your requirements
請注意,我刪除了表達式編譯步驟以縮短示例.應該重新添加它以提高性能.
Note that I've removed the expression compilation step to shorten the example. It should be re-added to improve performance.
這篇關于如何使用 Xpath 檢索 XML 樹的節點后的節點?的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!