我正在尝试使用Selenium Webdriver的 find_element_by_xpath 方法从以下HTML代码中提取联系电话(XXXXX-XXXXXX)。
<div id="contact-info">
<div class="a">
<div class="b">
<table class="c">
<tr>
<td class="d">
<div class="e">Contact Info</span></div>
</td>
<td class="f">
<div></div>
</td>
</tr>
</table>
</div>
<div class="g">
<div class="h">
<table>
<tr>
<td>
<div class="i"><span class="j">Mobile</span></div>
</td>
<td class="k">
<div class="random_class_name"><span><span dir="ltr">XXXXX-XXXXXX</span></span>
</div>
</td>
</tr>
</table>
</div>
这是我提取所需数据的代码-
print(browser.find_element_by_xpath('//div[@id="contact-info"]/div[1]/div[2]/div[1]/div[2]/span[1]/span[1]').text)
但是我抛出一个异常,说找不到元素。我在这里可能做错了什么?我该如何解决?
答案 0 :(得分:1)
使用:更正您的XPath
print(browser.find_element_by_xpath('//span[@dir="ltr"]').text)
答案 1 :(得分:1)
要获取Mobile-Number
,您可以引用文本Mobile
并查找下一个同级。
产生WebDriverWait
()并等待visibility_of_element_located
()并跟随xpath。
print(WebDriverWait(browser,10).until(EC.visibility_of_element_located((By.XPATH,"//td[.//div[contains(.,'Mobile')]]/following-sibling::td[1]/div"))).text)
您需要导入以下库。
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.common.by import By
from selenium.webdriver.support import expected_conditions as EC
答案 2 :(得分:1)
contactNumber = WebDriverWait(browser, 30).until(
EC.element_to_be_clickable((By.XPATH, "//div[@class='random_class_name']//span[1]//span")))
print contactNumber.text
或
contactNumber = WebDriverWait(browser, 30).until(
EC.element_to_be_clickable((By.XPATH, "//span[contains(text(), 'XXXXX-XXXXXX')]")))
print contactNumber.text
注意:在解决方案中添加以下内容:
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
from selenium.webdriver.common.by import By
更新的部分: 检查表是否在iframe中(如果是),然后使用下面的代码切换到iframe;
iframe=driver.find_element_by_tag_name("iframe")
driver.switch_to.frame(iframe)