Python中使用 Selenium 实现网页截图实例
程序员文章站
2024-03-30 23:40:51
selenium 是一个可以让浏览器自动化地执行一系列任务的工具,常用于自动化测试。不过,也可以用来给网页截图。目前,它支持 java、c#、ruby 以及 python...
selenium 是一个可以让浏览器自动化地执行一系列任务的工具,常用于自动化测试。不过,也可以用来给网页截图。目前,它支持 java、c#、ruby 以及 python 四种客户端语言。如果你使用 python,则只需要在命令行里输入“sudo easy_install selenium”并回车,即可安装 selenium 的 python 版本的客户端支持。
以 python 为例,我们可以使用下面的脚本来给指定页面(比如首页)截图:
# -*- coding: utf-8 -*- # # author: oldj <oldj.wu@gmail.com> # from selenium import webdriver import time def capture(url, save_fn="capture.png"): browser = webdriver.firefox() # get local session of firefox browser.set_window_size(1200, 900) browser.get(url) # load page browser.execute_script(""" (function () { var y = 0; var step = 100; window.scroll(0, 0); function f() { if (y < document.body.scrollheight) { y += step; window.scroll(0, y); settimeout(f, 50); } else { window.scroll(0, 0); document.title += "scroll-done"; } } settimeout(f, 1000); })(); """) for i in xrange(30): if "scroll-done" in browser.title: break time.sleep(1) browser.save_screenshot(save_fn) browser.close() if __name__ == "__main__": capture("//www.jb51.net")
注意到,上面的代码中,我并没有在打开页面后立即截图,而是先在页面上执行了一段 javascript 脚本,先将页面的滚动条拖到最下方,再拖回顶部,然后才截图。这样的好处是如果页面下方有一些延迟加载的内容,在这个操作之后一般也都已加载了。
与 pagesaver 等浏览器插件相比,selenium 功能更为强大,例如,它可以在页面上注入并执行一段 js,还可以模拟鼠标点击等行为,而且可以同时运行多个实例(多个线程同时截图)。这样看来,使用 selenium 来给页面截图似乎是一个不错的选择。
上一篇: 基于JSP的在线考试系统-JavaWeb项目-有源码
下一篇: 学习总结(一)java web连接池
推荐阅读
-
Python中使用 Selenium 实现网页截图实例
-
使用位运算实现网页中的过滤、筛选功能实例
-
使用位运算实现网页中的过滤、筛选功能实例
-
Python实现的网页截图功能【PyQt4与selenium组件】
-
Python使用selenium实现网页用户名 密码 验证码自动登录功能
-
python爬虫:使用xpath和find两种方式分别实现使用requests_html库爬取网页中的内容
-
Python实现的网页截图功能【PyQt4与selenium组件】
-
Python中使用 Selenium 实现网页截图实例
-
Python中使用 Selenium 实现网页截图实例
-
python中如何使用JPype实现调用java的实例分享