一文掌握Selenium的详细使用

文章目录

    • 1. 安装 Selenium
      • 1.1 安装 Selenium 库
      • 1.2 下载浏览器驱动
    • 2. 基础用法
      • 2.1 启动浏览器
      • 2.2 查找元素
      • 2.3 操作元素
    • 3. 高级功能
      • 3.1 等待机制
      • 3.2 处理弹窗
      • 3.3 执行 JavaScript
      • 3.4 切换窗口或 iframe
      • 3.5 处理 Cookies
      • 3.6 截图
      • 3.7 处理下拉菜单
    • 4. 浏览器选项
      • 4.1 无头模式(Headless)
      • 4.2 禁用图片加载
      • 4.3 设置代理
    • 5. 常见应用场景
      • 5.1 自动化登录
      • 5.2 抓取动态加载数据
      • 5.3 登录网站并获取数据
    • 6. 注意事项
    • 6. 总结

Selenium 是一个用于自动化浏览器操作的工具,广泛用于 Web 自动化测试、数据抓取和网页交互。它支持多种浏览器(如 Chrome、Firefox、Edge 等)和编程语言(如 Python、Java、C# 等)。本文将详细介绍如何使用 Python 中的 Selenium 进行浏览器自动化操作。

1. 安装 Selenium

1.1 安装 Selenium 库

使用 pip 安装 Selenium:pip install selenium

1.2 下载浏览器驱动

Selenium 需要通过浏览器驱动来控制浏览器。常用的浏览器驱动如下:

Chrome: ChromeDriver

Firefox: GeckoDriver

Edge: Microsoft Edge WebDriver

下载与浏览器版本匹配的驱动,并将其路径添加到系统的环境变量中,或者直接在代码中指定驱动路径。

2. 基础用法

2.1 启动浏览器

以下示例以 Chrome 浏览器为例:

from selenium import webdriver# 指定 ChromeDriver 路径
driver_path = '/path/to/chromedriver'# 创建浏览器实例
driver = webdriver.Chrome(executable_path=driver_path)# 打开网页
driver.get('https://www.example.com')# 关闭浏览器
driver.quit()

2.2 查找元素

Selenium 提供了多种查找元素的方法:
find_element_by_id() 通过 ID 查找元素
find_element_by_name() 通过 Name 查找元素
find_element_by_class_name() 通过 Class Name 查找元素
find_element_by_tag_name() 通过 Tag Name 查找元素
find_element_by_css_selector() 通过 CSS 选择器查找元素
find_element_by_xpath() 通过 XPath 查找元素
find_element_by_link_text() 通过链接文本查找元素
find_element_by_partial_link_text() 通过部分链接文本查找元素

示例:

# 通过 ID 查找
element = driver.find_element(By.ID, "element-id")# 通过类名查找
element = driver.find_element(By.CLASS_NAME, "element-class")# 通过标签名查找
element = driver.find_element(By.TAG_NAME, "div")# 通过 CSS 选择器查找
element = driver.find_element(By.CSS_SELECTOR, "div.class-name")# 通过 XPath 查找
element = driver.find_element(By.XPATH, "//div[@id='element-id']")

2.3 操作元素

找到元素后,可以对其进行各种操作:

输入文本:

element = driver.find_element_by_name('q')
element.send_keys('Selenium')

点击元素:

element = driver.find_element_by_id('submit-button')
element.click()

获取元素属性:

element = driver.find_element_by_id('element-id')
print(element.get_attribute('value'))  # 获取 value 属性

获取元素文本:

element = driver.find_element_by_class_name('class-name')
print(element.text)  # 获取元素的文本内容

3. 高级功能

3.1 等待机制

Selenium 提供了显式等待和隐式等待机制,用于处理页面加载或元素加载的延迟。

显式等待:显式等待会等待某个条件成立后再继续执行。

from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC# 等待最多 10 秒,直到元素出现
element = WebDriverWait(driver, 10).until(EC.presence_of_element_located((By.ID, 'element-id'))

隐式等待:隐式等待会在查找元素时等待一定时间。

driver.implicitly_wait(10)  # 设置隐式等待时间为 10 秒

3.2 处理弹窗

Selenium 可以处理浏览器的弹窗(如警告框、确认框、提示框)。

# 切换到弹窗
alert = driver.switch_to.alert# 获取弹窗文本
print(alert.text)# 接受弹窗(点击确定)
alert.accept()# 拒绝弹窗(点击取消)
alert.dismiss()

3.3 执行 JavaScript

可以通过 execute_script() 方法执行 JavaScript 代码。

# 滚动页面到底部
driver.execute_script('window.scrollTo(0, document.body.scrollHeight);')# 修改元素属性
driver.execute_script('document.getElementById("element-id").style.backgroundColor = "yellow";')

3.4 切换窗口或 iframe

切换窗口:当打开新窗口时,需要切换到新窗口。

# 获取当前窗口句柄
main_window = driver.current_window_handle# 打开新窗口
driver.find_element_by_link_text('Open New Window').click()# 切换到新窗口
for handle in driver.window_handles:if handle != main_window:driver.switch_to.window(handle)# 切换回主窗口
driver.switch_to.window(main_window)

切换 iframe:如果需要操作 iframe 中的元素,需要先切换到 iframe。

# 通过 ID 或 Name 切换
driver.switch_to.frame('iframe-id')# 切换回主页面
driver.switch_to.default_content()

3.5 处理 Cookies

Selenium 可以操作浏览器的 Cookies。

# 添加 Cookie
driver.add_cookie({'name': 'key', 'value': 'value'})# 获取 Cookie
print(driver.get_cookie('key'))# 删除 Cookie
driver.delete_cookie('key')# 删除所有 Cookies
driver.delete_all_cookies()

3.6 截图

可以截取当前页面的屏幕截图。

# 截图并保存
driver.save_screenshot('screenshot.png')

3.7 处理下拉菜单

from selenium.webdriver.support.ui import Select# 找到下拉菜单元素
select_element = driver.find_element(By.ID, "dropdown")# 创建 Select 对象
select = Select(select_element)# 通过文本选择
select.select_by_visible_text("Option 1")# 通过值选择
select.select_by_value("value1")# 通过索引选择
select.select_by_index(0)

4. 浏览器选项

4.1 无头模式(Headless)

from selenium.webdriver.chrome.options import Optionsoptions = Options()
options.add_argument("--headless")  # 启用无头模式
driver = webdriver.Chrome(options=options)

4.2 禁用图片加载

chrome_options = Options()
chrome_options.add_argument("--blink-settings=imagesEnabled=false")
driver = webdriver.Chrome(options=chrome_options)

4.3 设置代理

chrome_options = Options()
chrome_options.add_argument("--proxy-server=http://your-proxy-server:port")
driver = webdriver.Chrome(options=chrome_options)

5. 常见应用场景

5.1 自动化登录

from selenium import webdriverdriver = webdriver.Chrome(executable_path='/path/to/chromedriver')
driver.get('https://www.example.com/login')# 输入用户名和密码
driver.find_element_by_name('username').send_keys('your-username')
driver.find_element_by_name('password').send_keys('your-password')# 点击登录按钮
driver.find_element_by_id('login-button').click()driver.quit()

5.2 抓取动态加载数据

from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as ECdriver = webdriver.Chrome(executable_path='/path/to/chromedriver')
driver.get('https://www.example.com/dynamic-content')# 等待动态内容加载
element = WebDriverWait(driver, 10).until(EC.presence_of_element_located((By.CLASS_NAME, 'dynamic-content'))
print(element.text)driver.quit()

5.3 登录网站并获取数据

from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC# 启动浏览器
driver = webdriver.Chrome()# 打开登录页面
driver.get("https://www.example.com/login")# 输入用户名和密码
driver.find_element(By.ID, "username").send_keys("your_username")
driver.find_element(By.ID, "password").send_keys("your_password")# 点击登录按钮
driver.find_element(By.ID, "submit-button").click()# 等待页面加载完成
WebDriverWait(driver, 10).until(EC.presence_of_element_located((By.ID, "dashboard"))
)# 获取数据
data = driver.find_element(By.ID, "data").text
print(data)# 关闭浏览器
driver.quit()

6. 注意事项

​驱动版本匹配:确保浏览器驱动与浏览器版本匹配,否则会报错。

​反爬虫机制:部分网站会检测 Selenium 的使用,可以通过禁用自动化标志或使用代理绕过检测。

​性能优化:在爬虫中尽量减少不必要的操作(如滚动、点击),以提高效率。

​异常处理:使用 try-except 捕获异常,避免程序崩溃。

6. 总结

Selenium 是一个功能强大的浏览器自动化工具,适用于 Web 自动化测试、数据抓取和网页交互。通过掌握其基础用法和高级功能,你可以轻松实现各种浏览器自动化任务。在实际使用中,建议结合显式等待和异常处理,以提高脚本的稳定性和可靠性。

参考文档
Selenium 官方文档:https://www.selenium.dev/documentation/
ChromeDriver 下载:https://sites.google.com/chromium.org/driver/
GeckoDriver 下载:https://github.com/mozilla/geckodriver

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/24027.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

DeepSeek开源周 Day02:从DeepEP开源趋势重新审视大模型Infra

DeepEP 今天DeepSeek开源周第二天,开放了DeepEP仓库,属实看了下源码,和昨天FlashMLA一样,C权重(包括CUDA)还是占据了绝对部分,作为调包侠的我,看到之后望而却步,想看原理…

【Ambari】Ranger KMS

目录 一、Ranger KMS介绍 二、KMS基于Ranger插件安装 一、Ranger KMS介绍 Ranger KMS是把数据存储入后台数据库中。通过Ranger Admin可以集中化管理KMS服务。 Ranger KMS有三个优点 l Key management Ranger admin 提供了创建,更新,删除密钥的Web UI…

055 SpringCache

文章目录 缓存一致性Spring Cachepom.xmlapplication.ymlCubemallProductApplication.javaSpringCache改造三级分类MyCacheConfig.java缓存一致性 缓存一致性 锁 设置过期时间 读写锁 设置过期时间 Spring Cache 1.读模式 缓存穿透:查询一个null数据,…

神卓 S500 组网设备连接交换机的详细步骤

神卓 S500 组网设备连接交换机的详细步骤 神卓 S500 组网设备以其高效、灵活的解决方案,在异地监控组网中发挥着重要作用。本文将详细介绍神卓 S500 组网设备连接交换机的步骤,帮助您轻松实现网络的互联互通。 一、前期准备 确认设备型号与规格&#x…

图像处理案例06 OCR应用

OCR应用 1 OCR读取账单1.1 背景及思路1.2 代码 1 OCR读取账单 1.1 背景及思路 思路 目标是读取图片中账单的信息。首先要截取图片上的账单,考虑到账单并非都是整齐摆放,为了保持算法的通用性,通过透视变换对扣取的账单摆正,然后调…

2024最新版鸿蒙纯血原生应用开发教程文档丨学习ArkTS语言-基本语法

ArkTS是HarmonyOS的主要应用开发语言,在TypeScript基础上进行了扩展,保留了其基本风格,并通过增强静态检查和分析来提高程序的稳定性和性能。本教程将帮助开发者掌握ArkTS的核心功能、语法及最佳实践,以便高效地构建高性能移动应用…

【AIGC】使用Python实现科大讯飞语音服务ASR转录功能:完整指南

文章目录 讯飞ASR转写API完整指南1. 引言2. 讯飞ASR API介绍3. API参数说明3.1 认证参数3.2 上传参数3.3 查询结果参数3.4 orderResult 字段3.5 Lattice 字段3.6 json_1best 字段3.7 st 字段 4. Python代码实现4.1 生成签名4.2 上传音频文件4.3 获取转写结果4.4 解析转写结果 5…

微软开源神器OmniParser-v2.0本地部署教程

安装python环境 我这里是以前安装好的版本:python 3.11.5,这里不再介绍,有需要的可以在网上找教程。 安装Anaconda 我这里是以前安装好的版本:conda 23.7.4,这里也不再介绍,有需要的可以在网上找教程。 …

LLM+多智能体协作:基于CrewAI与DeepSeek的邮件自动化实践

文章目录 引言理解 Flows(工作流)与 Crews(协作组)一、环境准备与工具安装1.1 Python环境搭建1.2 创建并激活虚拟环境1.3 安装核心依赖库(crewai、litellm) 二、本地DeepSeek R1大模型部署2.1 Ollama框架安…

Linux——高级IO

一、前言概念 IO拷贝等待 1. 同步(Synchronous) vs 异步(Asynchronous) 核心区别:关注的是消息通知的机制。 同步:调用方主动等待结果,需持续检查任务是否完成。 异步:调用方发起…

Linux:基础IO

文章目录 一、理解"文件"1、狭义上的理解2、广义上的理解3、文件操作的认知4、系统角度 二、C语言文件接口1、ls /proc/[进程id] -l 命令查看当前正在运⾏进程的信息2、stdin 和 stdout 和 stderr 三、系统文件 I/O1、标志位传递的一种方法2、系统调用 open 三、文件…

zabbix数据采集以及自定义监控

目录 1.数据采集 2.自定义监控 2.1客户端 2.2服务端 ​​​​​​​1.数据采集 点击最新数据页面如下图 往下滑查看具体数据 并点击查看图像就可以看到图像了 就可以看到如下图内容 2.自定义监控 我们通过zabbix客户端任何模板就可以监控我们想要的任何资源 如果…

02.25 继承和多态

编写一个如下场景: 有一个英雄Hero类,私有成员,攻击,防御,速度,生命值,以及所有的set get 方法 编写一个 武器 Weapon 类,拥有私有成员攻击力,以及set get 方法 编写一个…

6. grafana的graph简介

1. Settings功能 2. Visualization功能 (可视化的方式,后续会写一些) 3. Display 功能(显示方面的设置) bars 柱状图方式显示 lines(不选不会出功能) line width 线条的粗细 staircase 会让折…

前缀和代码解析

前缀和是指数组一定范围的数的总和,常见的有两种,一维和二维,我会用两道题来分别解析 一维 DP34 【模板】前缀和 题目: 题目解析: 暴力解法 直接遍历数组,遍历到下标为 l 时,开始进行相加,直到遍历到下标为 r ,最后返回总和.这样做的时间复杂度为: O(n) public class Main …

RoCBert:具有多模态对比预训练的健壮中文BERT

摘要 大规模预训练语言模型在自然语言处理(NLP)任务上取得了最新的最优结果(SOTA)。然而,这些模型容易受到对抗攻击的影响,尤其是对于表意文字语言(如中文)。 在本研究中&#xff0…

【原创工具】文件清单生成器 By怜渠客

【原创工具】文件清单生成器 By怜渠客 刚在论坛看到了一个文件列表生成器 文件列表生成器 - 吾爱破解 - 52pojie.cn ,和我去年写的一个软件很像,当时我也是有需求,要把一个文件夹里及其子文件夹里所有的文件列出来,就临时弄了个小…

深度学习-6.用于计算机视觉的深度学习

Deep Learning - Lecture 6 Deep Learning for Computer Vision 简介深度学习在计算机视觉领域的发展时间线 语义分割语义分割系统的类型上采样层语义分割的 SegNet 架构软件中的SegNet 架构数据标注 目标检测与识别目标检测与识别问题两阶段和一阶段目标检测与识别两阶段检测器…

【Linux】初始操作系统和进程(一)

目录 前言: 一、冯诺依曼体系结构: 二、操作系统: 1.操作系统是什么? 2.为什么要有操作系统? 3.操作系统是如何管理下层的? 4.操作系统是如何对上层提供服务的? 三、进程: …

【链 表】

【链表】 一级目录1. 基本概念2. 算法分析2.1 时间复杂度2.2 空间复杂度2.3 时空复杂度互换 线性表的概念线性表的举例顺序表的基本概念顺序表的基本操作1. 初始化2. 插入操作3. 删除操作4. 查找操作5. 遍历操作 顺序表的优缺点总结优点缺点 树形结构图形结构单链表基本概念链表…