嗨,我是 Selenium Webdriver 的新手。请帮我解决这个问题。
HTML 结构如下:
<div> "other attibutes"
<span> "other attibutes"
<span> "other attibutes"
<span> "other attibutes" Text </span>
</span>
</span>
</div>
现在我正在编写这样的Java代码:
public getCustomText() {
List <WebElement> objSpanList = driver.findElement(By.id("dijit_layout_ContentPane_1")).findElements(By.tagName("span"));
for (WebElement e : objSpanList) {
System.out.println("The element text is : "+e.getText());
}
}
当我调用这个函数时,它的输出如下:
Text
Text
Text
输出中没有编译或运行时错误。
实际上只有最后一个span元素有文本,但对于上面的span标签它只有不同的属性,但没有元素文本。所有跨度元素都具有最后一个跨度元素的文本。所以我对 selenium web 驱动程序的行为感到困惑。
我不确定我是否得到正确的输出。或者这是上述生成树的 selenium Web 驱动程序的默认性质。
所以请向我解释一下这里到底发生了什么或者我这边有一些错误。
最佳答案
您有 3 <span>
元素,一个在另一个元素内,所以即使你自己承认,你的输出也是准确的:“所有跨度元素都具有最后一个跨度元素的文本”。
您可以更改:
List <WebElement> objSpanList = driver.findElement(By.id("dijit_layout_ContentPane_1")).findElements(By.tagName("span"));
致:
WebElement innerSpan = driver.findElement(By.xpath(\\div\span\span\span"));
关于java - 如何使用 Selenium Webdriver 和 Java 从包含在多个 span 标签内的 span 元素中获取实际文本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21182406/