0


关于Selenium滚动条的处理

1.普通滚动条的处理,例如百度首页检索后的滚动条

from selenium import webdriver
from time import sleep
from selenium.webdriver.common.by import By
driver = webdriver.Chrome()
driver.get('https://www.baidu.com')
driver.maximize_window()
sleep(5)
driver.find_element(By.ID, 'kw').send_keys('python')
driver.find_element(By.ID, 'su').click()
sleep(10)
js="var q=document.documentElement.scrollTop=5000" 
driver.execute_script(js)

2.对于iframe中的滚动条

首先要进入iframe内,然后在进行使用driver.execute_script(),具体方法同上,只是在执行execute_script方法前先执行driver.switch_to.frame()

3.对于一些自适应的数据滚动条。

有些数据并不是网页自带的滚动条,而是数据超过页面最大显示数量,所通过前端处理生成的滚动条,并且这些数据是只有当前页的数据才能通过selenium定位到,此刻需要定位到某个具体的元素,先进行跳转,然后在进行等待刷新,在进行捕捉数据。

ele = driver.find_element(By.ID, 'vW1vR')
js4 = "arguments[0].scrollIntoView();"
driver.execute_script(js4, ele)

举个例子,网站有50条数据,但是页面只能显示10条,并且通过selenium去获取元素拿值得时候,发现只能拿到当前页面显示得十条数据,剩下得五十条数据,必须通过向下滚动,页面显示出来得时候才能捕捉到,此刻就需要使用到上面得方法。


本文转载自: https://blog.csdn.net/weixin_43985642/article/details/126176495
版权归原作者 WRH一坨 所有, 如有侵权,请联系我们删除。

“关于Selenium滚动条的处理”的评论:

还没有评论