我有以下HTML代码,我正在尝试运行我的selenium测试
<html>
<head></head>
<body>
<table id="Original">
<tr>
<td>Original-11</td>
<td>Original-12</td>
<td>Original-13</td>
</tr>
<tr>
<td>Original-21</td>
<td>Original-22</td>
<td>Original-23</td>
</tr>
<tr>
<td>Original-31</td>
<td>Original-32</td>
<td>Original-33</td>
</tr>
</table>
<br/><br/>
<table id="Duplicate">
<tr>
<td>Duplicate-11</td>
<td>Duplicate-12</td>
<td>Duplicate-13</td>
</tr>
<tr>
<td>Duplicate-21</td>
<td>Duplicate-22</td>
<td>Duplicate-23</td>
</tr>
<tr>
<td>Duplicate-31</td>
<td>Duplicate-32</td>
<td>Duplicate-33</td>
</tr>
</table>
</body>
</html>
&#13;
selenium java代码如下所示:
public static void main(String[] args) throws Exception
{
System.setProperty("webdriver.chrome.driver", System.getProperty("user.dir") + "/src/test/drivers/chromedriver.exe");
WebDriver drv = new ChromeDriver();
drv.get("C:/Users/MYUserName/git/er_test/SeleniumTestHtml.html");
WebElement tableElement = drv.findElement(By.id("Duplicate"));
WebElement rowElement = tableElement.findElement(By.xpath("//tr[2]"));
WebElement cellElement = rowElement.findElement(By.xpath("//td[2]"));
System.out.println(rowElement.getText());
System.out.println(cellElement.getText());
drv.close();
drv.quit();
}
我期待的结果如下:
重复-21重复-22重复-23
重复-22
但我得到了这个结果:
原装-21原装-22原装-23
原始-12
我在这里做错了吗?
答案 0 :(得分:7)
您的问题是//
会让您返回搜索顶级根元素。
这意味着
WebElement rowElement = tableElement.findElement(By.xpath("//tr[2]"));
和
一样好WebElement rowElement = driver.findElement(By.xpath("//tr[2]"));
如果您只需要在当前元素内搜索,那么您应该使用
WebElement rowElement = tableElement.findElement(By.xpath(".//tr[2]"));