在python中使用Selenium从span元素中提取文本

时间:2020-04-08 16:34:10

标签: python html selenium xpath webdriver

我正在尝试使用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)

但是我抛出一个异常,说找不到元素。我在这里可能做错了什么?我该如何解决?

3 个答案:

答案 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)
相关问题