我有下表,我想要一个表达式得到类别"OC“的百分比。可以通过XPath提取吗?
<tbody>
<tr>
<th class="textL">Category</th>
<th class="textR">No. of Items</th>
<th class="textR">Percentage</th>
</tr>
<tr class="data_row">
<td>OC</td>
<td class="textR">100</td>
<td class="textR">4.70</td>
</tr>
<tr class="data_row">
<td>FP</td>
<td class="textR">200</td>
<td class="textR">38.82</td>
</tr>
<tr class="data_row">
<td>FI</td>
<td class="textR">300</td>
<td class="textR">20.39</td>
</tr>
</tbody>发布于 2015-05-20 17:24:10
根据另一项的值选择表项
为指定的"OC“类别选择百分比:
//td[.='OC']/following-sibling::td[count(../..//th[.='Percentage']/preceding-sibling::th)]/text()上面的XPath将返回
"4.70"应要求。
请注意,只要目标列继续被命名为“百分比”,并且在第一列中的类别列之后,它将继续在许多更改(包括行和列重排)面前工作。我们甚至可以通过取两列位置的不同来进一步概括这个表达式,而不是假设类别是第一列。
解释性:在包含"OC“的td中,检查与”百分比“列标题位置相等的兄弟姐妹数,然后在正确的同级td中选择文本。
发布于 2015-05-20 16:16:19
另一个XPath,也依赖于表的列的顺序
//td[text()='OC']/following-sibling::td[2](说明:以包含文本‘OC’的td兄弟姐妹中的第二个兄弟姐妹为例。)
发布于 2015-05-20 15:47:25
这方面有多个XPaths。这一项将起作用:
/tbody[1]/tr[2]/td[3]/text()但是它基于XML当前的布局。
https://stackoverflow.com/questions/30354338
复制相似问题