Python 实现网页自动截图的示例讲解


Posted in Python onMay 17, 2018

背景介绍

最近在为部门编写一个自动化测试工具,工具涉及到一个功能,即 将自动化测试生成的html报告截图,作为邮件正文,html文件上传到web服务器以链接形式添加到邮件中,最后发送邮件。

任务难点

之前从未接触过页面自动截图相关的方面,因此如何自动进行页面截图成为本地调研方向。

方案思考

在刚接到这个任务时,并不认同目前的方案。曾经一度认为,将html报告的内容写入邮件正文,即可通过html的形式发送邮件了。经过尝试后发现,邮件不支持带javascript的html。因此,选择了预览html并自动截图的方案。

编程语言

python 2.7

使用方案 :

selenium + phantomjs

方案介绍

实现自动预览html并截图有以下几个步骤:

1. 浏览器打开html

2. 对浏览器页面进行截图

3. 将截图保存到指定位置

最初,笔者使用了这个实现方案:

(1).使用webbrowser 库打开默认浏览器,显示url

Python 实现网页自动截图的示例讲解

(2).使用PIL.ImageGrab库的对屏幕进行进行截图

Python 实现网页自动截图的示例讲解

到此为止,笔者已经获得html的预览截图,一切似乎很顺利,但接下来

发现了以下几个问题:

(1).打开默认浏览器时,默认浏览器是什么,浏览器处于什么状态都不知晓。

(2).浏览器显示html,会有一个显示的打开浏览器,浏览器打开html的动作出现,如果用户此时产生了其他动作,必定会对之后的截图产生影响。

(3).屏幕截图,将整个屏幕都进行截图,截图中除了html页面正文,同时也包含了浏览器等当前屏幕包含的所有元素,暴漏了用户隐私。

(4).如果页面较大,页面会产生上下翻页的效果,屏幕截图无法应对此种页面,截图看到的报告只有一部分。

基于上述问题,笔者放弃了这个看起来简单有效的方案。从而

对方案挖掘了一些深层需求:

(1).打开浏览器必须隐式调用,用户无法看到工具在做什么,从而不会通过误操作对工具产生影响。

(2).截图必须针对浏览器页面正文 ,保证无其他冗余信息,且截到页面全图根据这些需求,笔者经过一系列尝试终于发现了selenium + phantomjs。

python selenium : 是python对浏览器自动化测试框架selenium的扩展,selenium库支持了selenium所包含大部分功能。

phantomjs : 是一个无界面的,可脚本编程的webkit浏览器,python selenium同样提供对phantomjs的支持。

接下来一切就很容易了:

(1).安装python selenium 库,推荐使用pip快速安装最新版本

(2).下载phantomjs.exe,将其添加到环境变量 path 中 。方便起见可以直接放在python的安装目录根目录下

(3).编写测试代码

Python 实现网页自动截图的示例讲解

简单讲解一下代码:

fromselenium importwebdriver     #从selenium库导入webdirver

brower=webdriver.PhantomJS()    #使用webdirver.PhantomJS()方法新建一个phantomjs的对象,这里会使用到phantomjs.exe,环境变量path中找不到phantomjs.exe,则会报错

brower.get(url)           #使用get()方法,打开指定页面。注意这里是phantomjs是无界面的,所以不会有任何页面显示

brower.maximize_window()      #设置phantomjs浏览器全屏显示

brower.save_screenshot(picName)   #使用save_screenshot将浏览器正文部分截图,即使正文本分无法一页显示完全,save_screenshot也可以完全截图

brower.close()           #关闭phantomjs浏览器,不要忽略了这一步,否则你会在任务浏览器中发现许多phantomjs进程

执行了上述代码后,我们看一下截图效果吧:

Python 实现网页自动截图的示例讲解

以上这篇Python 实现网页自动截图的示例讲解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python读写配置文件的方法
Jun 03 Python
详解Python函数可变参数定义及其参数传递方式
Aug 02 Python
Python提取频域特征知识点浅析
Mar 04 Python
pandas.read_csv参数详解(小结)
Jun 21 Python
Python实现的ftp服务器功能详解【附源码下载】
Jun 26 Python
在python中画正态分布图像的实例
Jul 08 Python
详解Python中的各种转义符\n\r\t
Jul 10 Python
kali中python版本的切换方法
Jul 11 Python
python3模拟实现xshell远程执行liunx命令的方法
Jul 12 Python
opencv导入头文件时报错#include的解决方法
Jul 31 Python
Python如何批量生成和调用变量
Nov 21 Python
python 对图片进行简单的处理
Jun 23 Python
Python操作Sql Server 2008数据库的方法详解
May 17 #Python
Python读写及备份oracle数据库操作示例
May 17 #Python
Python selenium抓取微博内容的示例代码
May 17 #Python
Python实现的查询mysql数据库并通过邮件发送信息功能
May 17 #Python
Python实现读取txt文件并转换为excel的方法示例
May 17 #Python
cmd运行python文件时对结果进行保存的方法
May 16 #Python
Python基于lxml模块解析html获取页面内所有叶子节点xpath路径功能示例
May 16 #Python
You might like
在PHP中使用反射技术的架构插件使用说明
2010/05/18 PHP
Gambit vs CL BO3 第三场 2.13
2021/03/10 DOTA
在JavaScript中遭遇级联表达式陷阱
2007/03/08 Javascript
用js实现上传图片前的预览(TX的面试题)
2007/08/14 Javascript
javascript 面向对象编程基础:继承
2009/08/21 Javascript
jquery在IE、FF浏览器的差别详细探讨
2013/04/28 Javascript
js动态设置div的值下例子
2013/10/29 Javascript
javascript ajax 仿百度分页函数
2013/10/29 Javascript
jquery下div 的resize事件示例代码
2014/03/09 Javascript
jQuery实现隔行背景色变色
2014/11/24 Javascript
浅析jQuery EasyUI中的tree使用指南
2014/12/18 Javascript
JavaScript中自带的 reduce()方法使用示例详解
2016/08/10 Javascript
jQuery动态增减行的实例代码解析(推荐)
2016/12/05 Javascript
Vuejs 组件——props数据传递的实例代码
2017/03/07 Javascript
js+html5实现页面可刷新的倒计时效果
2017/07/15 Javascript
Vue 中的compile操作方法
2018/02/26 Javascript
vue中使用[provide/inject]实现页面reload的方法
2019/09/30 Javascript
vue实现前端列表多条件筛选
2020/10/26 Javascript
python显示生日是星期几的方法
2015/05/27 Python
python使用folium库绘制地图点击框
2018/09/21 Python
使用PyQtGraph绘制精美的股票行情K线图的示例代码
2019/03/14 Python
对django后台admin下拉框进行过滤的实例
2019/07/26 Python
Python3网络爬虫开发实战之极验滑动验证码的识别
2019/08/02 Python
pytorch 固定部分参数训练的方法
2019/08/17 Python
Python实现自定义读写分离代码实例
2019/11/16 Python
python3 使用openpyxl将mysql数据写入xlsx的操作
2020/05/15 Python
HTML5 embed标签定义和用法详解
2014/05/09 HTML / CSS
End Clothing美国站:英国男士潮牌商城
2018/04/20 全球购物
白俄罗斯大卖场:21vek.by
2019/07/25 全球购物
正风肃纪剖析材料
2014/02/18 职场文书
喝酒检查书范文
2014/02/23 职场文书
工程质量承诺书
2014/03/27 职场文书
吨的认识教学反思
2014/04/27 职场文书
品酒会策划方案
2014/05/26 职场文书
陈安之励志演讲稿
2014/08/21 职场文书
2015年敬老月活动总结
2015/03/27 职场文书