如何使用 Selenium 在 <span> 中查找元素文本?

How to Find Element Text within <span> using Selenium?

我是 Python 和 Selenium 的新手,到目前为止,我的脚本可以做我想做的事,但我有来自网站的当前编码:

<a onclick="realPostBack('ctl00$ctl00$mainContent$ContentPlaceHolder1$ucHub$ucSearchExplorer$dgContents$ctl00$ctl04$lnkContent', ''); return false;" id="ctl00_ctl00_mainContent_ContentPlaceHolder1_ucHub_ucSearchExplorer_dgContents_ctl00_ctl04_lnkContent" class="hub-content-item" actiontype="Secondary" href="javascript:__doPostBack('ctl00$ctl00$mainContent$ContentPlaceHolder1$ucHub$ucSearchExplorer$dgContents$ctl00$ctl04$lnkContent','')"><span>How to Project Wirelessly in Philly</span></a> 

我无法点击 link。

我试过:

driver.find_element_by_text("How to Project Wirelessly in Philly")

和部分文字

driver.find_element_by_id("ctl00_ctl00_mainContent_ContentPlaceHolder1_ucHub_ucSearchExplorer_dgContents_ctl00_ctl04_lnkContent")

我试过按标签,但都返回错误。抬头看这里,我看到了 Xpath 的东西,但我不知道该怎么做,但如果这里有人这样做,那么可以提供一点帮助,或者任何其他希望让我点击它的简单代码 link. (我知道我必须执行 .click() 才能最终单击它,但我什至找不到该元素)

所需的元素是动态元素,因此在其上调用 click() 您必须诱导 WebDriverWait 才能使 元素可点击,您可以使用以下任一解决方案:

  • 使用CSS_SELECTOR:

    element = WebDriverWait(driver, 20).until(EC.element_to_be_clickable((By.CSS_SELECTOR, "a.hub-content-item[id*='SearchExplorer'][actiontype='Secondary']>span")))
    
  • 使用XPATH:

    element = WebDriverWait(driver, 20).until(EC.element_to_be_clickable((By.XPATH, "//a[@class='hub-content-item' and contains(@id,'SearchExplorer')][@actiontype='Secondary']/span[text()='How to Project Wirelessly in Philly']")))
    
  • 注意:您必须添加以下导入:

    from selenium.webdriver.support.ui import WebDriverWait
    from selenium.webdriver.common.by import By
    from selenium.webdriver.support import expected_conditions as EC