python - 使用 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)
但这会产生一个空数组。我真的不确定我做错了什么。任何帮助将不胜感激。谢谢
解决方案
您必须添加预期条件以等待页面加载数据。
您可以等待您正在使用的元素的可见性,然后获取它的文本,如下所示:
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)
推荐阅读
- laravel - 如何从 URL laravel 7 中隐藏 id?
- css - Vuejs组件中如何排列元素
- javascript - 自定义挂钩如何在引擎盖下工作?
- symlink - 我们可以在符号链接目录下创建文件吗?
- typescript - Vuex模块中的Typescript错误“当作为表达式调用时无法解析类装饰器的签名”
- javascript - 表单未提交,不确定这是否与验证码有关
- javascript - 如何用createElement渲染Vue的动态组件标签?
- snowflake-cloud-data-platform - 什么是磁盘溢出意味着以及如何在雪花中避免这种情况
- html - 如何删除所有默认锚样式以使元素不受影响?
- python - 冒泡排序算法和“int”对象不可下标