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 相关文章推荐
Python3实现并发检验代理池地址的方法
Sep 18 Python
python使用fcntl模块实现程序加锁功能示例
Jun 23 Python
Python如何通过subprocess调用adb命令详解
Aug 27 Python
python3读取csv和xlsx文件的实例
Jun 22 Python
Python使用MyQR制作专属动态彩色二维码功能
Jun 04 Python
Python 计算任意两向量之间的夹角方法
Jul 05 Python
python的移位操作实现详解
Aug 21 Python
python3常用的数据清洗方法(小结)
Oct 31 Python
python实现画循环圆
Nov 23 Python
python3格式化字符串 f-string的高级用法(推荐)
Mar 04 Python
python按顺序重命名文件并分类转移到各个文件夹中的实现代码
Jul 21 Python
关于PySnooper 永远不要使用print进行调试的问题
Mar 04 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实现的博客欢迎提示功能(很特别哦)
2014/06/05 PHP
php遍历CSV类实例
2015/04/14 PHP
PHP使用栈解决约瑟夫环问题算法示例
2017/08/27 PHP
thinkphp5框架扩展redis类方法示例
2019/05/06 PHP
JS刷新当前页面的几种方法总结
2013/12/24 Javascript
完美实现仿QQ空间评论回复特效
2015/05/06 Javascript
easyui Draggable组件实现拖动效果
2015/08/19 Javascript
RequireJS入门一之实现第一个例子
2015/09/30 Javascript
jQuery实现微信长按识别二维码功能
2016/08/26 Javascript
js中小数向上取整数,向下取整数,四舍五入取整数的实现(必看篇)
2017/02/13 Javascript
如何快速上手Vuex
2017/02/14 Javascript
单击按钮发送验证码,出现倒计时的简单实例
2017/03/17 Javascript
详解如何将 Vue-cli 改造成支持多页面的 history 模式
2017/11/20 Javascript
nodejs之koa2请求示例(GET,POST)
2018/08/07 NodeJs
Vue+Vuex实现自动登录的知识点详解
2020/03/04 Javascript
JavaScript实现横版菜单栏
2020/03/17 Javascript
手写Vue源码之数据劫持示例详解
2021/01/04 Vue.js
Python3搜索及替换文件中文本的方法
2015/05/22 Python
Python简单连接MongoDB数据库的方法
2016/03/15 Python
Python使用openpyxl读写excel文件的方法
2017/06/30 Python
MAC中PyCharm设置python3解释器
2017/12/15 Python
Django后台获取前端post上传的文件方法
2018/05/28 Python
Python基于Logistic回归建模计算某银行在降低贷款拖欠率的数据示例
2019/01/23 Python
Python远程视频监控程序的实例代码
2019/05/05 Python
如何在Python中实现goto语句的方法
2019/05/18 Python
PyQT实现菜单中的复制,全选和清空的功能的方法
2019/06/17 Python
对python中的装包与解包实例详解
2019/08/24 Python
python解释器pycharm安装及环境变量配置教程图文详解
2020/02/26 Python
意大利一家专营包包和配饰的网上商店:Borse Last Minute
2019/08/26 全球购物
俄罗斯茶和咖啡网上商店:Tea.ru
2021/01/26 全球购物
个人授权委托书样本
2014/09/13 职场文书
2015年中秋节演讲稿
2015/03/20 职场文书
爱国主义主题班会
2015/08/14 职场文书
安全生产协议书
2016/03/22 职场文书
logback如何自定义日志存储
2021/08/30 Java/Android
SQL Server中锁的用法
2022/05/20 SQL Server