首页 > 解决方案 > 使用 XPATH 和 Python 选择元素?

问题描述

我正在尝试确定印度中央污染控制委员会生成的数据页数。这是一个输出示例。在https://github.com/RachitKamdar/Python-Scraper之后,我使用了 selenium/python

maxpage = int(browser.find_elements(By.XPATH,"//*[@id='DataTables_Table_0_paginate']/span/a")[-1].text)

但这会产生一个空数组。我真的不确定我做错了什么。任何帮助将不胜感激。谢谢

标签: pythonseleniumxpath

解决方案


您必须添加预期条件以等待页面加载数据。
您可以等待您正在使用的元素的可见性,然后获取它的文本,如下所示:

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

wait = WebDriverWait(driver, 20)
wait.until(EC.visibility_of_element_located((By.XPATH, "//*[@id='DataTables_Table_0_paginate']/span/a")))
maxpage = int(browser.find_elements(By.XPATH,"//*[@id='DataTables_Table_0_paginate']/span/a")[-1].text)


推荐阅读