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中使用多进程来实现并行处理的方法小结
Aug 09 Python
Python实现的爬虫刷回复功能示例
Jun 07 Python
解决Python2.7中IDLE启动没有反应的问题
Nov 30 Python
python文档字符串(函数使用说明)使用详解
Jul 30 Python
wxPython:python首选的GUI库实例分享
Oct 05 Python
Python线程指南分享
Nov 19 Python
opencv设置采集视频分辨率方式
Dec 10 Python
Python pandas如何向excel添加数据
May 22 Python
python实现计算器简易版
Dec 17 Python
浅析Python模块之间的相互引用问题
Feb 26 Python
python pygame入门教程
Jun 01 Python
OpenCV全景图像拼接的实现示例
Jun 05 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 删除cookie和浏览器重定向
2009/03/16 PHP
php学习之简单计算器实现代码
2011/06/09 PHP
php计算整个mysql数据库大小的方法
2015/06/19 PHP
PHP下SSL加密解密、验证、签名方法(很简单)
2020/06/28 PHP
微信公众平台开发-微信服务器IP接口实例(含源码)
2017/03/05 PHP
在Javascript中为String对象添加trim,ltrim,rtrim方法
2006/09/22 Javascript
jQuery旋转插件—rotate支持(ie/Firefox/SafariOpera/Chrome)
2013/01/16 Javascript
jQuery图片切换插件jquery.cycle.js使用示例
2014/06/16 Javascript
浅谈Javascript线程及定时机制
2015/07/02 Javascript
跟我学习javascript的arguments对象
2015/11/16 Javascript
jQuery调用Webservice传递json数组的方法
2016/08/06 Javascript
JavaScript生成验证码并实现验证功能
2016/09/24 Javascript
jQuery+ajax实现局部刷新的两种方法
2017/06/08 jQuery
JavaScript模拟实现封装的三种方式及写法区别
2017/10/27 Javascript
vue实现局部刷新的实现示例
2019/04/16 Javascript
使用Vue-cli3.0创建的项目 如何发布npm包
2019/10/10 Javascript
JS实现拼图游戏
2021/01/29 Javascript
js实现数字滚动特效
2019/12/16 Javascript
Python中的多重装饰器
2015/04/11 Python
Python中for循环控制语句用法实例
2015/06/02 Python
一个基于flask的web应用诞生 使用模板引擎和表单插件(2)
2017/04/11 Python
Python列表推导式与生成器表达式用法示例
2018/02/08 Python
用python做游戏的细节详解
2019/06/25 Python
Selenium+Python 自动化操控登录界面实例(有简单验证码图片校验)
2019/06/28 Python
Python math库 ln(x)运算的实现及原理
2019/07/17 Python
HTML5中通过li-canvas轻松实现单图、多图、圆角图绘制,单行文字、多行文字等
2018/11/30 HTML / CSS
土木工程建筑专业毕业生求职信
2013/10/21 职场文书
艺术设计专业个人求职信
2014/04/10 职场文书
装修协议书范本
2014/04/21 职场文书
党务公开方案
2014/05/06 职场文书
个人租房协议书(范本)
2014/10/14 职场文书
茶楼服务员岗位职责
2015/02/09 职场文书
人事聘任通知
2015/04/21 职场文书
通知函的格式
2015/04/27 职场文书
居住证明范文
2015/06/17 职场文书
毕业证明模板
2015/06/19 职场文书