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去获取元素拿值得时候,发现只能拿到当前页面显示得十条数据,剩下得五十条数据,必须通过向下滚动,页面显示出来得时候才能捕捉到,此刻就需要使用到上面得方法。