selenium截屏代码

复制代码
六、截屏
   应用场景:失败截图,让错误看的更直观
   方法: 
      driver.get_screenshot_as_file(imgepath)
   参数:
      imagepath:为图片要保存的目录地址及文件名称
         如: 当前目录 ./test.png
             上一级目录 ../test.png
   扩展:
      1. 多条用例执行失败,会产生多张图片,可以采用时间戳的形式,进去区分。
      操作: 
         driver.get_screenshot_as_file("../image/%s.png"%(time.strftime("%Y_%m_%d %H_%M_%S")))
         strftime:将时间转为字符串函数
   注意:
      %Y_%m_%d %H_%M_%S:代表,年 月 日 时 分 秒
python 复制代码
# 导包
import time
from time import strftime
from selenium import webdriver
from time import sleep
# 获取浏览器驱动对象
from selenium.webdriver.common.by import By

driver = webdriver.Firefox()
# 最大化浏览器
driver.maximize_window()
# 隐式等待
driver.implicitly_wait(30)
# 打开url
url = r"C:\Users\黄永生\Desktop\软件测试\P2C电子市场\web自动化_day01_课件+笔记+资料+代码\02_其他资料\注册A.html"
driver.get(url)


"""
    目标: 截屏
    方法:
        driver.get_screenshot_as_file()
    需求:
        1. 输入用户名
        2. 截图 当前目录下 admin.png
"""
# 输入 admin
driver.find_element(By.CSS_SELECTOR,"#userA").send_keys("admin")
# 调用截图方法
# driver.get_screenshot_as_file("./admin.png")
# 存放指定目录
# driver.get_screenshot_as_file("../scripts/admin02.png")
# driver.get_screenshot_as_file("../image/admin.png")

# 动态获取文件名称 使用时间戳
# driver.get_screenshot_as_file("../image/%s.png"%(time.strftime("%Y_%m_%d %H_%M_%S")))
# driver.get_screenshot_as_file("../image/%s.jpg"%(time.strftime("%Y_%m_%d %H_%M_%S")))
driver.get_screenshot_as_file("../image/%s.jpg"%(strftime("%Y_%m_%d %H_%M_%S")))



# 暂停 2
sleep(2)
# 关闭驱动对象
driver.quit()
相关推荐
大猫子的技术日记1 分钟前
Redis 快速上手实战教程:从零搭建高性能缓存系统
数据库·redis·缓存
莳花微语2 分钟前
记录一次生产中mysql主备延迟问题处理
数据库·mysql
Hello.Reader9 分钟前
Flink JDBC Driver把 Flink SQL Gateway 变成“数据库”,让 BI / 工具 / 应用直接用 JDBC 跑 Flink SQL
数据库·sql·flink
李宥小哥9 分钟前
SQLite02-安装
数据库
一 乐12 分钟前
景区管理|基于springboot + vue景区管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·学习
JIngJaneIL15 分钟前
基于java + vue连锁门店管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot
阿拉伯柠檬16 分钟前
MySQL内置函数(二)
linux·数据库·mysql·面试
月明长歌19 分钟前
怎么把 SQL 的增删改查写成“稳、准、可维护”的
java·数据库·sql
南汐以墨21 分钟前
UI自动化测试指南(二):常用方法
java·测试工具
小蜗牛的路21 分钟前
MySQL-连接很慢,10秒钟才有响应、Temporary failure in name resolution
数据库·mysql