python 自动点击按钮_Python+Selenium使用(二)- 自动点击下一页

这篇博客介绍了如何使用Python的Selenium库自动点击页面的下一页按钮,并解决因CSS选择器问题导致的切换限制。同时,文章讨论了页面滚动的实现,包括通过JavaScript进行页面滚动以及滚动至特定元素可见的必要性,以应对动态加载的内容。
摘要由CSDN通过智能技术生成

f62d9923bdc278d8249fd9a78de576cb.png

继续上一篇:

橘猫吃不胖:Python+Selenium使用(一)​zhuanlan.zhihu.com
e5442e3200bbad1c6624f31f6da7c05d.png

上一篇,获取了百度搜索后的结果页面,但是搜索结果又很多页,这里就获取下一页按钮,并点击它。


现在浏览器上,找到下一页按钮:

bb509656b7b69e7d966b953c77b968b7.png
    btn = driver.find_element_by_css_selector('div.page-inner > a.n')
    print(btn.get_property('href'))    
    btn.click()

这里,就是用css来定位了“下一页”按钮,运行后,就可以看到自动切换到了下一页

顺便记录一个问题,就是css selector,貌似不能跨层级,“div.page-inner > a.n”

一开始想用div的id去找,但是一直找不到

b5a2bb2d4535f951f7272c0640ab5ce9.png

后来改了这个page_inner就可以了

然后,就想多点几次,但是好像哪里有问题,只在第一页、第二页切换

flag = 1
while  flag<10:
    btn = driver.find_element_by_css_selector('div.page-inner > a.n')
    print(btn.get_property('href'))    
    btn.click()
    time.sleep(random.randint(1,9))                                      
    flag += 1

看了下HTML

f9c77bc1982e439042f29ade97539065.png

当切换到下一页的时候,上一页的class也是n

0ba5728be7b087b41aa3e111c0b2b43c.png

然后,换了一下选择器的写法

flag = 1
while  flag<10:
    btn = driver.find_element_by_css_selector('a.n:last-child')
    print(btn.text, ':', btn.get_property('href'))    
    btn.click()
    time.sleep(random.randint(5,9))                                      
    flag += 1

这下就可以了

关于选择器可以看看这个:CSS 选择器参考手册

现在是这样子的,每次页面更新后,我是手工滑动到页面的最下面,看页面切换是否一致

有点儿麻烦,如果可以自动滑动到下面就好了

滚动页面

selenium中没有直接操作页面滚动的方法,但是我们可以通过调用JS的方式来实现

driver.execute_script('window.scrollBy(0,200)')

这样就可以滚动200个单位,应该是像素

当然,也可以让页面滚动到我们想要看到的元素那里

    btn = driver.find_element_by_css_selector('a.n:last-child')
    
    driver.execute_script("arguments[0].scrollIntoView();",btn)

上面,我们获取了“下一页”按钮,这里,可以直接滚动到“下一页”按钮可见

3476bd2ff9b0769488ca4b76a06a77ca.png

让页面滚动,还有一个原因,现在很多页面都是动态加载,如果你的页面不滚动,某些元素就不会加载出来,直接去定位的话,也找不到这个元素

所以,才会需要页面来滚动

除了上面说的按照像素来滚动,滚动到某元素可见,还可以直接根据页面的高度来滚动

driver.execute_script("window.scrollTo(0,document.body.scrollHeight)")

1c15d53e8202c91f7407252c99fb3010.png

如果页面动态加载,高度不断变化,这里可能还会有问题,这里后面具体场景再确认一下

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值