当前位置: 首页 > backend >正文

Selenium 自动化实战技巧【selenium】

🧰 更多 Selenium 自动化操作技巧

1️⃣ 鼠标交互操作(ActionChains)

Selenium 提供 ActionChains 类来模拟用户的复杂鼠标行为,如:

  • 移动光标到某元素上(悬浮触发事件)
  • 鼠标右键、双击
  • 拖拽元素等

📌 示例:模拟将鼠标移动到百度首页的“更多产品”菜单上:

from selenium.webdriver.common.action_chains import ActionChainsac = ActionChains(driver)
target = driver.find_element(By.CSS_SELECTOR, '[name="tj_briicon"]')
ac.move_to_element(target).perform()

2️⃣ 执行 JavaScript 脚本

Selenium 支持直接执行 JS 脚本,用于获取 DOM 属性或处理页面行为。

示例:检查分页按钮是否可用
disabled = driver.execute_script('''let ele = document.querySelector('.soupager > button:last-of-type');return ele.getAttribute('disabled');
''')if disabled == 'disabled':return True
将元素滚动到视口中(避免点击失败)
driver.execute_script("arguments[0].scrollIntoView({block:'center',inline:'center'})", element)

3️⃣ 冻结页面以辅助调试

某些浮动菜单或弹窗,在鼠标移出时会立即消失,不方便抓取元素信息。可在浏览器开发者工具的控制台执行:

setTimeout(function(){debugger}, 5000)

在 5 秒内将鼠标悬停目标区域,随后浏览器将冻结当前界面,便于检查 HTML 结构。


4️⃣ 处理弹窗(Alert、Confirm、Prompt)

Selenium 提供 switch_to.alert 接口操作 JS 弹窗:

Alert 弹窗(只包含提示信息)
driver.switch_to.alert.text  # 获取内容
driver.switch_to.alert.accept()  # 点击确认
Confirm 弹窗(确认/取消选择)
driver.switch_to.alert.accept()   # 确认
driver.switch_to.alert.dismiss()  # 取消
Prompt 弹窗(输入内容)
alert = driver.switch_to.alert
alert.send_keys("selenium自动化")
alert.accept()

❗提示:非 JS 弹窗(HTML 构建)需用正常元素选择器处理。


5️⃣ 控制窗口与页面信息

获取或设置浏览器窗口参数:

  • driver.get_window_size():获取尺寸
  • driver.set_window_size(w, h):设置大小
  • driver.title:页面标题
  • driver.current_url:当前地址栏内容
print(driver.title)
print(driver.current_url)

6️⃣ 页面截图

使用 get_screenshot_as_file() 保存当前界面截图:

driver.get_screenshot_as_file('screenshot.png')

7️⃣ 模拟手机设备

通过 ChromeOptions 配置移动设备环境,模拟手机访问网页:

from selenium import webdrivermobile_emulation = {"deviceName": "iPhone 14 Pro Max"}
chrome_options = webdriver.ChromeOptions()
chrome_options.add_experimental_option("mobileEmulation", mobile_emulation)driver = webdriver.Chrome(options=chrome_options)
driver.get('https://www.baidu.com')

8️⃣ 文件上传(支持多文件)

上传控件一般是 <input type="file">,只需通过 send_keys 指定文件路径:

ele = wd.find_element(By.CSS_SELECTOR, 'input[type="file"]')
ele.send_keys(r'h:\test.png')

📂 多文件上传(支持多次调用):

ele.send_keys(r'h:\img1.png')
ele.send_keys(r'h:\img2.png')

📌 如果上传控件不是标准的 file input,而是弹出系统窗口,可以借助 Windows 平台的 pywin32 库发送文件路径和回车:

import win32com.client
shell = win32com.client.Dispatch("WScript.Shell")
shell.Sendkeys(r"h:\img.png" + '\n')

9️⃣ 自动化 Edge 浏览器

Edge(基于 Chromium)需要下载对应版本的驱动,初始化方式如下:

from selenium import webdriverdriver = webdriver.Edge(executable_path=r'd:\tools\webdrivers\msedgedriver.exe')
driver.get('https://www.51job.com')

这就是 Selenium 在常见交互行为、弹窗处理、浏览器控制、上传文件、移动端模拟等方面的进阶用法整理。

http://www.xdnf.cn/news/15171.html

相关文章:

  • springboot生成pdf方案之dot/html/图片转pdf三种方式
  • PDF 转图助手 PDF2JPG 绿色版:免安装直接用,急处理文件的救急小天使
  • 技术突破与落地应用:端到端 2.0 时代辅助驾驶TOP10 论文深度拆解系列【第九篇(排名不分先后)】
  • GPT和MBR分区
  • 云蝠智能 VoiceAgent重构企业呼入场景服务范式
  • 重学前端004 --- html 表单
  • 从二维到三维:数字孪生如何重塑UI前端设计
  • 【Git】git的回退功能
  • Flutter优缺点
  • 港科大 NMPC 控制下的高效自主导航!SkyVLN:城市环境无人机视觉语言导航与非线性模型预测控制
  • 哪些因素会影响NMR杂质检测的准确性
  • 全面掌控 Claude Code:命令 + 参数 + 快捷键一文全整理(建议收藏)
  • Linux的基础I/O
  • 如何在 PyCharm 批量调整代码缩进?PyCharm 调整代码格式化和代码缩进的快捷键有哪些?
  • S7-1200 与 S7-300 CPS7-400 CP UDP 通信 Step7 项目编程
  • 最常用的JS加解密场景MD5
  • Vue 3 入门——自学习版本
  • 分布式推客系统全栈开发指南:SpringCloud+Neo4j+Redis实战解析
  • C#事件:从原理到实践的深度剖析
  • 微软语音合成标记语言SSML文档结构和事件(详细文档和实例)
  • 基于Python的豆瓣图书数据分析与可视化系统【自动采集、海量数据集、多维度分析、机器学习】
  • Ubuntu20.04运行openmvg和openmvs实现三维重建(未成功,仅供参考)
  • AI金融风控:识别欺诈,量化风险的新利器
  • 批量合并全国地理信息资源目录服务系统下载的全国基础地理数据
  • JAVA JVM垃圾收集
  • JavaScript 异步编程指南:async/await 与 Promise 该怎么选?
  • 中国银联豪掷1亿采购海光C86架构服务器
  • 第十五章 STL(stack、queue、list、set、map容器使用)
  • 基于Selenium和FFmpeg的全平台短视频自动化发布系统
  • Linux小白学习基础内容