<tbody>
<tr>
<td>January</td>
<td>$100</td>
</tr>
<tr>
<td>February</td>
<td>$80</td>
</tr>
</tbody>
从下面的简单表中可以看到,找到文本等于“1月”的表格列很简单:“tr / td [text()='January']” 但是td可能会变得复杂,因为它可能包含嵌套元素。所以我们最好提供另一个By参数。
我的问题是如何编写可以执行此搜索的通用方法。我有一个下面,但不好,findTableRowsBy(1,By.xpath(“text()='January'”))将导致异常。有人可以帮我擦亮这个方法吗?非常感谢。
public List<WebElement> findTableRowsBy( int column, By theBy )
{
By by = By.xpath( "tbody[1]/tr/td[" + column + "]" );
List<WebElement> cols = table.findElements( by );
List<WebElement> rows = new ArrayList<WebElement>();
for( WebElement e : cols )
{
List<WebElement> eles = e.findElements( theBy );
if( eles.isEmpty() )
continue;
if( eles.size() == 1 )
rows.add( eles.get( 0 ) );
}
return rows;
}
答案 0 :(得分:0)
也许,您也可以使用以下xpath:
//td[contains(text(), "January")]
我猜你应该能找到合适的td,即使它有嵌套元素。