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简单文本处理的方法
Jul 10 Python
Python模拟用户登录验证
Sep 11 Python
Python实现爬虫抓取与读写、追加到excel文件操作示例
Jun 27 Python
Python走楼梯问题解决方法示例
Jul 25 Python
python xpath获取页面注释的方法
Jan 14 Python
java判断三位数的实例讲解
Jun 10 Python
使用python来调用CAN通讯的DLL实现方法
Jul 03 Python
对Python函数设计规范详解
Jul 19 Python
python2.7实现复制大量文件及文件夹资料
Aug 31 Python
python 截取XML中bndbox的坐标中的图像,另存为jpg的实例
Mar 10 Python
pandas分批读取大数据集教程
Jun 06 Python
理解深度学习之深度学习简介
Apr 14 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
yii2.0实现pathinfo的形式访问的配置方法
2016/04/06 PHP
解决Laravel 不能创建 migration 的问题
2019/10/09 PHP
javascript基本类型详解
2014/11/28 Javascript
js图片翻书效果代码分享
2015/08/20 Javascript
vuejs在解析时出现闪烁的原因及防止闪烁的方法
2016/09/19 Javascript
详解利用exif.js解决ios手机上传竖拍照片旋转90度问题
2016/11/04 Javascript
ES6新特性之变量和字符串用法示例
2017/04/01 Javascript
基于 Bootstrap Datetimepicker 联动
2017/08/03 Javascript
详解webpack中的hash、chunkhash、contenthash区别
2018/01/05 Javascript
手写Node静态资源服务器的实现方法
2018/03/20 Javascript
Vue.js 使用v-cloak后仍显示变量的解决方法
2018/11/19 Javascript
[原创]微信小程序获取网络类型的方法示例
2019/03/01 Javascript
30分钟用Node.js构建一个API服务器的步骤详解
2019/05/24 Javascript
JavaScript实现轮播图效果代码实例
2019/09/28 Javascript
vue中更改数组中属性,在页面中不生效的解决方法
2019/10/30 Javascript
小程序接入腾讯位置服务的详细流程
2020/03/03 Javascript
vue-resource post数据时碰到Django csrf问题的解决
2020/03/13 Javascript
vue+vant 上传图片需要注意的地方
2021/01/03 Vue.js
[00:56]2014DOTA2国际邀请赛 DK、iG 赛前探访
2014/07/10 DOTA
python之matplotlib学习绘制动态更新图实例代码
2018/01/23 Python
PyQt5每天必学之单行文本框
2018/04/19 Python
python下载库的步骤方法
2019/10/12 Python
python @propert装饰器使用方法原理解析
2019/12/25 Python
Jupyter安装链接aconda实现过程图解
2020/11/02 Python
python爬虫scrapy框架的梨视频案例解析
2021/02/20 Python
Scrapy实现模拟登录的示例代码
2021/02/21 Python
金鑫耀Java笔试题
2014/09/06 面试题
土木工程应届生求职信
2013/10/31 职场文书
住宅质量保证书
2014/04/29 职场文书
小学教师师德承诺书
2014/05/23 职场文书
高中物理教学反思
2016/02/19 职场文书
告诉你一个秘密:富人致富的五大优点
2019/07/11 职场文书
Django 如何实现文件上传下载
2021/04/08 Python
Linux安装apache服务器的配置过程
2021/11/27 Servers
html粘性页脚的具体使用
2022/01/18 HTML / CSS
Vue Mint UI mt-swipe的使用方式
2022/06/05 Vue.js