Selenium常用操作、鼠标键盘事件、滚动条

Selenium常用操作、鼠标键盘事件、滚动条


1、窗口操作

from selenium import webdriver
import time
 
dr = webdriver.Chrome()
wd = dr.get('http://baidu.com/')
 
# 设置窗口设置
dr.set_window_position(30,50)   # 设置窗口所在屏幕上的位置
time.sleep(1)
dr.set_window_position(80,100)    # 修改窗口所在屏幕上的位置
print(dr.get_window_position())   # 获取窗口在屏幕上的位置坐标
time.sleep(1)
dr.set_window_size(800,300)  # 设置窗口指定大小
print(dr.get_window_size())  # 获取浏览器窗口大小
time.sleep(1)
dr.minimize_window()  # 设置窗口最小化
time.sleep(1)
dr.maximize_window()  # 设置窗口最大化
 
# 浏览器的前进与后退及刷新
dr.find_element_by_css_selector('#form input#kw').send_keys('python')
dr.find_element_by_css_selector('input#su').click()
time.sleep(1)
dr.back()  # 后退
time.sleep(1)
dr.forward()  # 前进
time.sleep(1)
dr.refresh()  # 刷新
time.sleep(1)
 
dr.quit()

2、鼠标事件

在selenium当中除了简单的点击动作外,还有一些稍微复杂的动作,就需要用到ActionChains(动作链)这个子模块来满足需求。 鼠标操作的方法封装在ActionChains类中,为了方便使用,首先需要导入这个类。所有的动作执行后都需要使用perform()方法提交才可以成功。
在这里插入图片描述

from selenium import webdriver
from selenium.webdriver import ActionChains
 
# 鼠标事件(括号中参数为要执行的目标元素)
ActionChains.click()   # 单击
ActionChains.perform()  # 执行所有存储的行为,即对对应操作的提交
ActionChains.context_click()  # 右击
ActionChains.double_click()  # 双击
ActionChains.drag_and_drop(a,b)  # 拖动,a为原元素,b为释放鼠标后的目标元素
ActionChains.move_to_element()   # 鼠标悬停

3、键盘事件

键盘事件操作的方法存放在Keys()类中,需要先导入
from selenium.webdriver.common.keys import Keys

from selenium import webdriver
from selenium.webdriver.common.keys import Keys
 
# 键盘事件(鼠标执行事件都是通过send_keys()命令,括号中的参数指定对应的键盘操作),跟多操作查询官网
Keys.BACK_SPACE  # 删除键(Backspace)
Keys.SPACE   # 空格键
Keys.TAB    # 制表符Tab
Keys.ESCAPE   # 回退键Esc
Keys.ENTER   # 回车
Keys.CONTROL,'a'  # 全选
Keys.CONTROL,'c'  # 复制
Keys.CONTROL,'x'  # 剪切
Keys.CONTROL,'v'  # 黏贴
Keys.F12    # F1——F12

4、滚动条

浏览器滚动条到最下方的代码(适合滚动加载使用),window.scrollTo() 参数,滚动条的横向距离和纵向距离

方法一:

每次滚动到最下方

        # 定义一个初始值表示滚动条与顶部的距离
        original_top = 0
        while True:
            # 循环下拉滚动条
            self.wd.execute_script("window.scrollTo(0,document.body.scrollHeight)")
            time.sleep(0.5)
            # 获取当前滚动条距离顶部的距离
            check_height = self.wd.execute_script(
                "return document.documentElement.scrollTop || window.pageYOffset || document.body.scrollTop;")
            # 如果滚动条距离上面的距离不再改变,也就是滚动后的距离和之前距离顶部的位置没有改变,说明到达最下方,跳出循环
            if check_height == original_top:
                break
            original_top = check_height

方法二:

每次滚动设定距离

 # 定义一个初始值表示滚动条与顶部的距离
        original_top = 0
        while True:
            # 循环下拉滚动条
            self.wd.execute_script("window.scrollBy(0,500)")
            time.sleep(0.5)
            check_height = self.wd.execute_script(
                "return document.documentElement.scrollTop || window.pageYOffset || document.body.scrollTop;")
            # 如果滚动条距离上面的距离不再改变,也就是滚动后的距离和之前距离顶部的位置没有改变,说明到达最下方,跳出循环
            if check_height == original_top:
                break
            original_top = check_height

两段代码不同之处在于execute_script中的参数window.scrollTo,和 window.scrollBy ,window.scrollBy(在设置每次滚动设定距离时使用较好),在获取当前滚动条距离顶部的距离时,某些浏览器会有所不同。

其他方向的滚动

滚动到元素对象的“底端”与当前窗口的“底部”对齐 :

execute_script("arguments[0].scrollIntoView(false);",element)

滚动到元素对象的“顶端”与当前窗口的“顶部”对齐:

execute_script("arguments[0].scrollIntoView();",element)
  • 4
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值