[英]Can't get text from element in selenium from outside tag?
我有以下要素
<td nowrap="nowrap" align="left" colspan="2">
<b>Zone: </b>
"521X 7SW "
</td>
如何獲取包含“ 521X 7SW”的文本? 每次我在selenium中嘗試.text命令時,它只會返回“ Zone:”。 如果我使用get_attibute(“ text”)命令,則不會返回任何內容。
我已經使用此命令選擇了元素
zone = driver.find_element_by_xpath("//*[contains(text(), 'Zone')]")
那是一個文本節點,而不僅僅是文本。
您可以像這樣注入Javascript:
text_node = driver.find_element_by_xpath("//b[contains(text(),'Zone: ')]")
data = driver.execute_script("return arguments[0].nextSibling.textContent;", text_node)
print(data)
text_node作為arguments[0]
傳遞給Javascript arguments[0]
您要查找的文本與' b '標簽無關,它是td標簽的text()
值。 您應該找到td標簽文本以獲取“ 521X 7SW”值。
driver.find_element_by_xpath("//td[@nowraap='nowrap']/text()");
您可以優化td的xpath,因為我在問題中僅使用了顯示的HTML 。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.