Selenium.Webdriver最新语法教程(附Chrome实例演示)

这篇具有很好参考价值的文章主要介绍了Selenium.Webdriver最新语法教程(附Chrome实例演示)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

 “ 随着selenium库的不断更新,现有教程部分语法不适用于当前版本,故笔者写下此篇教程供初学者学习使用、老手快速查询调库使用 。” 

  • 编程环境:Pycharm
  • 浏览器:Chrome
  • 示例网站:www.baidu.com
  • 教程内容:Selenium.Webdriver语法、ActionChains库语法、Keys库列表
  • Selenium.Webdriver:模拟浏览器行为
  • ActionChains库:模拟键盘、模拟鼠标行为
  • Keys库列表:模拟按键对应字符串对照列表
  • 根据需求按照目录自由跳转学习即可

 驱动下载与导入

  • 点击链接Chrome Webdriver下载入口选择当前浏览器版本对应的驱动
  • Pycharm 导入 selenium包
  • 驱动提取
from selenium import webdriver
from selenium.webdriver.chrome.service import Service

s = Service(r'F:\Download\Browser\Edge\chromedriver.exe')  # 存储驱动所在路径
d = webdriver.Chrome(service=s)  # 从路径提取驱动,设置驱动名为d
d.implicitly_wait(60)  # 设置每个步骤最大等待时间
d.get('https://www.baidu.com')  # GET方法访问百度

Selenium八大定位语法

  • Tips :快速获取网页元素标识内容,步骤:点击网页元素-右键-检查
  • Tips :css\xpath标识内容可通过浏览器快速获取,步骤:选择元素源代码-右键-copy-导出
d.find_element('id', 'id标识内容')
d.find_element('css selector', 'css标识内容').send_keys()

d.find_element('link text', '文本标识内容')
d.find_element('partial link text', '部分文本标识内容')

d.find_element('name', 'name标识内容')
d.find_element('class name', 'class标识内容')
d.find_element('tag name', 'tag name标识内容')
d.find_element('xpath', 'xpath标识内容')

# 常结合输入框输入参数,更多语法详见下文:ActionChains库
d.find_element('id', '输入框的id').send_keys('输入框的输入内容')

网页操作

基本操作

d.implicitly_wait('秒数')     # 设置最大等待时间
d.implicitly_wait(60)    # 设置最大等待时间为60秒

d.refresh()     # 刷新当前窗口
d.forward()    # 网页前进
d.back()   # 网页后退

d.maximize_window()     # 最大化当前驱动窗口
d.minimize_window()     # 最小化当前驱动窗口
d.fullscreen_window()  # 网页全屏,调用窗口管理器特定的“全屏”操作


d.get_cookie('name的名称')     # 通过name获得一个cookie
d.get_cookies()     # 返回对应于当前会话可见的所有cookies,返回类型为字典

d.start_client()    # 自定义开启会话,创建新session前调用
d.stop_client()  # 自定义结束会话,结束一个session后调用
# d.start_session('字典:支撑会话功能的字典')

自动截屏

d.get_screenshot_as_file('filename')    # 当前页面截屏保存为png图片,可指定路径,bool
d.get_screenshot_as_file('r"/figure/sc.png')    # 文件名后缀png不能少
d.get_screenshot_as_png()   # 当前页面截屏保存为png格式,数据形式为binary data

窗口参数获取与设置

# get 为获取,set为设置
d.get_window_rect()     # 当前窗口x,y坐标和长度、宽度
d.get_window_position()     # 当前窗口x、y坐标
d.get_window_size()     # 当前窗口长度、宽度

d.set_window_rect('x坐标', 'y坐标', '宽度', '高度')
d.set_window_position('x坐标', 'y坐标', windowHandle='current')
d.set_window_size('宽度', '高度', windowHandle='current')

窗口切换与变量获取

# 工作窗口、frame等切换:swith_to
d.switch_to.default_content()    # 切换到默认页
d.switch_to.frame('frame_name')    # 切换到指定frame
d.switch_to.parent_frame()    # 切换到父frame
d.switch_to.window('main')    # 切换到主窗口

# 保存操作,需要赋予变量存储
source = d.page_source      # 保存当前页面的源
title = d.title     # 保存当前页面title
handlers = d.current_window_handle      # 保存所有窗口句柄
handler = d.current_window_handle       # 保存当前窗口句柄
outs = d.timeouts   # 保存当前页面所有超时

# swith_to 和保存操作结合
element = d.switch_to.active_element
alert = d.switch_to.alert

ActionChains库

“Action库是selenium中提供模拟鼠标、键盘行为的库 。”

 库的导入和相关原则

# 使用语句 from selenium.webdriver import ActionChains 导入外部动作驱动
# d为上文定义的浏览器驱动,实例化得到浏览器外部动作驱动ad
ad = ActionChains(d)    # 行为链实例化,输入参数为驱动,
ad.perform()    # 行为开始执行的标识,必不可少!!!!!!

# 行为链以队列形式保存,执行时顺序执行
# perform()为行为链开始执行的标识
# 行为链演示
# 顺序执行:先点击,再输入,最后移动
ad.click('点击的元素').send_keys('输入的元素').move_to_element('移动的目的地').perform()


# 此模块的学习需要建立在元素定位的基础上,点击的元素均需要通过定位获取
# 示例:单击通过id定位的元素A:1.定位 2.单击 3.执行
A = d.find_element('id', '我是元素A的id标识')  # 定位元素A
ad = ActionChains(d)    # 实例化外部动作驱动
ad.click(A).perform()   # 单击并执行

# 其他:
ad.send_keys('输入内容')        # 对当前元素输入指定内容
ad.send_keys_to_element('输入内容')     # 对指定元素输入指定内容
ad.reset_actions()      # 重置行为,清除已有的行为

 模拟鼠标

# 模拟鼠标操作
# 如果不传入参数则默认执行位置为鼠标当前坐标

ad.click('单击的元素').perform()   # 单击执行
ad.double_click('双击的元素').perform()      # 双击执行
ad.context_click('点击的文本').perform()     # 点击文本执行


# 以下仅做语法讲解,没有perform表示不执行,实际应用需要在合适位置加perform
ad.click_and_hold('单击并长按的元素')       # 单击并长按
ad.release('释放的元素')     # 释放单击长按的元素


ad.drag_and_drop('开始元素', '结束元素')    # 鼠标左键滑动(按位置)
ad.drag_and_drop_by_offset('开始元素', 'x坐标偏移量', 'y坐标偏移量')  # 鼠标左键滑动(按偏移量)

ad.scroll(3, 4, 30, 40)     # 鼠标滚轮,参数依次为x起始坐标、y起始坐标、x坐标滚动量、y坐标滚动量

模拟键盘

# 组合键使用,通常一起出现,执行完动作后记得松开按键
ad.key_down('按下的按键', '按下的位置')
ad.key_up('松开的按键', '松开的位置')

# 当使用按键时,通常会使用Keys库,通过语句 from selenium.webdriver import Keys 获取Keys库
# 示例,在位置A,按下ctrl键,并松开
ad.key_down(Keys.CONTROL, A)
ad.key_up(Keys.CONTROL, A)

# Keys库支持的按键类型详见下文
# 不使用Keys库,也可通过字符串代替,按键对应字符串详见下文Keys库
# 例如:
# 在位置A按下ctrl
# ad.key_down('\ue009', A)

 Keys库

“ 提供模拟键盘快捷输入,以及对应字符串代码供参考使用 。”

ADD = '\ue025'
ALT = '\ue00a'
ARROW_DOWN = '\ue015'
ARROW_LEFT = '\ue012'
ARROW_RIGHT = '\ue014'
ARROW_UP = '\ue013'
BACKSPACE = '\ue003'
BACK_SPACE = '\ue003'
CANCEL = '\ue001'
CLEAR = '\ue005'
COMMAND = '\ue03d'
CONTROL = '\ue009'
DECIMAL = '\ue028'
DELETE = '\ue017'
DIVIDE = '\ue029'
DOWN = '\ue015'
END = '\ue010'
ENTER = '\ue007'
EQUALS = '\ue019'
ESCAPE = '\ue00c'
F1 = '\ue031'
F10 = '\ue03a'
F11 = '\ue03b'
F12 = '\ue03c'
F2 = '\ue032'
F3 = '\ue033'
F4 = '\ue034'
F5 = '\ue035'
F6 = '\ue036'
F7 = '\ue037'
F8 = '\ue038'
F9 = '\ue039'
HELP = '\ue002'
HOME = '\ue011'
INSERT = '\ue016'
LEFT = '\ue012'
LEFT_ALT = '\ue00a'
LEFT_CONTROL = '\ue009'
LEFT_SHIFT = '\ue008'
META = '\ue03d'
MULTIPLY = '\ue024'
NULL = '\ue000'
NUMPAD0 = '\ue01a'
NUMPAD1 = '\ue01b'
NUMPAD2 = '\ue01c'
NUMPAD3 = '\ue01d'
NUMPAD4 = '\ue01e'
NUMPAD5 = '\ue01f'
NUMPAD6 = '\ue020'
NUMPAD7 = '\ue021'
NUMPAD8 = '\ue022'
NUMPAD9 = '\ue023'
PAGE_DOWN = '\ue00f'
PAGE_UP = '\ue00e'
PAUSE = '\ue00b'
RETURN = '\ue006'
RIGHT = '\ue014'
SEMICOLON = '\ue018'
SEPARATOR = '\ue026'
SHIFT = '\ue008'
SPACE = '\ue00d'
SUBTRACT = '\ue027'
TAB = '\ue004'
UP = '\ue013'
ZENKAKU_HANKAKU = '\ue040'

 文章来源地址https://www.toymoban.com/news/detail-818995.html

到了这里,关于Selenium.Webdriver最新语法教程(附Chrome实例演示)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Selenium入门详细教程+实例演示

    目录 1.Selenium概述    1.1什么是Selenium    1.2Selenium的优势    1.3Selenium WebDriver原理 2.Selenium环境搭建 3.Selenium 简单示例 4.八大元素定位    4.1定位方式    4.2定位方式的用法 5.Selenium API    5.1WebDriver 常用 API    5.2WebElement 常用 API    5.3代码示例 6.元素等待机制    6.1硬性等待

    2024年02月13日
    浏览(39)
  • selenium-webdriver-Chrome新驱动地址(Chrome115及以上版本)

    Chrome115、Chrome116、Chrome117,在旧的链接并没有 新地址:https://googlechromelabs.github.io/chrome-for-testing/

    2024年02月04日
    浏览(53)
  • 解决selenium使用webdriver.Chrome()报错的问题

    谷歌驱动下载地址: https://sites.google.com/a/chromium.org/chromedriver/home   运行成功(打开浏览器显示chrome正在受自动化软件测试的控制就代表成功):  找到def __init__(self, executable_path=\\\"chromedriver\\\", port=0, 修改executable_path=\\\"chromedriver\\\" 为executable_path=\\\"chromedriver驱动的路径\\\"   修改成功后

    2024年02月11日
    浏览(55)
  • Selenium Chrome Webdriver 如何获取 Youtube 悬停文本

    导语 Youtube 是一个非常流行的视频分享平台,有时候我们可能想要爬取一些视频的信息,比如标题、播放量、点赞数等。但是有些信息并不是直接显示在网页上的,而是需要我们将鼠标悬停在某个元素上才能看到,比如视频的时长、上传时间等。这些信息被称为悬停文本,它

    2024年02月07日
    浏览(38)
  • Chrome自动升级了,找不到最新版本的webdriver怎么办?

    我用Selenium开发了Facebook和Linkedin爬虫,有些新需求要调一下,今天启动selenium时有报错,报错如下: selenium.common.exceptions.SessionNotCreatedException: Message: session not created: This version of ChromeDriver only supports Chrome version xxx Current browser version is xxx with binary path ,意思是Webdriver的版本与

    2024年02月07日
    浏览(54)
  • 报错 ‘selenium.webdriver‘ has no attribute ‘Chrome‘

    小白在搭建python环境并创建第一个selenium项目后,调用chromedriver插件时,代码报错: ‘selenium.webdriver‘ has no attribute ‘Chrome‘    前提条件:已安装selenium,chromedriver插件放在正确路径下并添加到环境变量。 解决方法:参考调用chrome插件失败 当前项目虚拟环境下的解释器环

    2024年02月12日
    浏览(46)
  • Selenium安装WebDriver Chrome驱动(含 116/117/118/119/120/)

    1、确认浏览器的版本 在浏览器的地址栏,输入 chrome://version/ ,回车后即可查看到对应版本 2、找到对应的chromedriver版本 2.1 114及之前的版本可以通过点击下载chromedriver,根据版本号(只看大版本)下载对应文件 2.2 116版本通过点击下载chromedriver,便可直接下载压缩包。 2.3 116/1

    2024年02月06日
    浏览(48)
  • linux下安装 Chrome 和 chromedriver 以及 selenium webdriver 使用

    chromedriver 下载地址: https://googlechromelabs.github.io/chrome-for-testing/ (推荐,包含最新稳定版) https://chromedriver.storage.googleapis.com/index.html? http://npm.taobao.org/mirrors/chromedriver/ https://registry.npmmirror.com/-/binary/chromedriver/ 查看版本: chromedriver对应下载地址 现在就可以使用 selenium 的 web

    2024年02月08日
    浏览(72)
  • selenium使用 webdriver.Chrome() 报错,找不到执行文件的解决方法(一)

    使用 driver = webdriver.Chrome() 时,遇到以下报错: selenium.common.exceptions.WebDriverException: Message: \\\'chromedriver\\\' executable needs to be in PATH. 两种解决方法: (1)在webdriver.Chrome()中添加executable_path参数,参数value = chromedriver.exe文件所在路径,示例: from selenium import webdriver chrome_driver_path

    2024年02月11日
    浏览(79)
  • Selenium + Chrome WebDriver + JS:实现高级爬虫技巧,获取网页响应状态码!

    随着爬虫技术的发展,我们使用requests库能够轻松获取响应状态码,但对于Selenium爬虫,同样可以迎刃而解。通过执行JavaScript脚本,我们可以智能地捕获网页的响应状态码,实现高级的爬虫功能。 在开始之前,确保你已正确安装Selenium和Chrome WebDriver,并配置好环境变量。 以下

    2024年02月07日
    浏览(54)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包