什么是Selenium

本文涉及的产品
对象存储 OSS,20GB 3个月
阿里云盘企业版 CDE,企业版用户数5人 500GB空间
日志服务 SLS,月写入数据量 50GB 1个月
简介: 什么是Selenium

image.png


# 01、模拟浏览器:Selenium

我们知道,网页会使用JavaScript加载数据,对应于这种模式,可以通过分析数据接口来进行直接抓取,这种方式需要对网页的内容、格式和JavaScript代码有所研究才能顺利完成。但有时还会碰到另外一些页面,这些页面同样使用AJAX技术,但是其页面结构比较复杂,很多网页中的关键数据由AJAX获得,而页面元素本身也使用JavaScript来添加或修改,甚至于人们感兴趣的内容在原始页面中并不出现,需要进行一定的用户交互(如不断下拉滚动条)才会显示。对于这种情况,为了方便,就会考虑使用模拟浏览器的方法来进行抓取,而不是通过“逆向工程”去分析AJAX接口,使用模拟浏览器的方法,特点是普适性强,开发耗时短,抓取耗时长(模拟浏览器的性能问题始终令人忧虑),使用分析AJAX的方法,特点则刚好与模拟浏览器相反,甚至在同一个网站、同一个类别中的不同网页上,AJAX数据的具体访问信息都有差别,因此开发过程投入的时间和精力成本是比较大的。如果碰到页面结构相对复杂或者AJAX数据分析比较困难(如数据经过加密)的情况,就需要考虑使用浏览器模拟的方式了。

在Python模拟浏览器进行数据抓取方面,Selenium永远是绕不过去的一个坎。Selenium(意为化学元素“硒”)是浏览器自动化工具,在设计之初是为了进行浏览器的功能测试。Selenium的作用,直观地说,就是使得操纵浏览器进行一些类似普通用户的操作成为可能,如访问某个地址、判断网页状态、单击网页中的某个元素(按钮)等。使用Selenium来操控浏览器进行的数据抓取其实已经不能算是一种“爬虫”程序,一般谈到爬虫,自然想到的是独立于浏览器之外的程序,但无论如何,这种方法有助于解决一些比较复杂的网页抓取任务,由于直接使用了浏览器,麻烦的AJAX数据和JavaScript动态页面一般都已经渲染完成,利用一些函数,完全可以做到随心所欲地抓取,加之开发流程也比较简单,因此有必要进行基本的介绍。

Selenium本身只是个工具,而不是一个具体的浏览器,但是Selenium支持包括Chrome和Firefox在内的主流浏览器。为了在Python中使用Selenium,需要安装selenium库(仍然通过pip install selenium的方式进行安装)。完成安装后,为了使用特定的浏览器,可能需要下载对应的驱动。将下载到的文件放在某个路径下。并在程序中指明该路径即可。如果想避免每次配置路径的麻烦,可以将该路径设置为环境变量,这里就不再赘述了。

通过一个访问百度新闻站点的例子来引入selenium库,代码如下:
js from selenium import webdriver import time browser = webdriver.Chrome('yourchromedriverpath')井如"/home/zyang/chromedriver browser.get('http:www.baidu.com') print(browser.title) #输出:“百度一下,你就知道” browser.find element by name("tj trnews").click()#单击头条browser.find element by class name('hdline0').click()print(browser.current url) #单击“新闻” 井输出: http://news.baidu.com/ time.sleep(10) browser.quit() #退出
运行上面的代码,会看到Chrome程序被打开,浏览器访问了百度首页,然后跳转到了百度新闻页面,之后又选择了该页面的第一个头条新闻,从而打开了新的新闻页。一段时间后,浏览器关闭并退出。控制台会输出“百度一下,你就知道”(对应browser.title)和 http://news.baidu.com/(对应browser.current_url)。这无疑是一个好消息,如果能获取对浏览器的控制权,那么爬取某一部分的内容会变得如臂使指。

另外,selenium库能够提供实时网页源码,这使得通过结合Selenium和BeautifulSoup(以及其他上文所述的网页元素解析方法)成为可能,如果对selenium库自带的元素定位API不甚满意,那么这会是一个非常好的选择。总的来说,使用selenium库的主要步骤如下。

① 创建浏览器对象,即使用类似下面的语句:
js from selenium import webdriver webdriver.Chrome()browser =
② 访问页面,主要使用browser.get方法,传入目标网页地址。

③ 定位网页元素,可以使用selenium自带的元素查找API,即
js = browser.find_element by_id("id")element element = browser.find element by name("name") element = browser.find element by xpath("xpath")element = browser.find element by link text('link text') #...
还可以使用browser.page_source获取当前网页源码并使用BeautifulSoup等网页解析工具定位:
js from selenium import webdriver from bs4 import BeautifulSoup browser = webdriver.Chrome('yourchromedriverpath')url = 'https://www.douban.com'browser.get(url) ht = BeautifulSoup(browser.page source,'lxml')for one in ht.find all('a',class ='title'):print(one.text) #输出: #52 倍人生--戴锦华大师电影课 ..... #觉知即新生一-终止童年创伤的心理修复课

④ 网页交互,对元素进行输入、选择等操作。如访问豆瓣并搜索某一关键字(效果见图1)的代码如下。
js from selenium import webdriver import time from selenium.webdriver.common.by import By browser = webdriver.Chrome('yourchromedriverpath')browser.get('http://www.douban.com')time.sleep(1) search box = browser.find_element(By.NAME,q')search box.send keys( 网站开发)button = browser.find element(By.CLASS NAME,bn')button.click()

image.png


■ 图1 使用Selenium操作Chrome进行豆瓣搜索的结果

在导航(窗口中的前进与后退)方面,主要使用browser.back和browser.forward两个函数。

⑤ 获取元素属性。可供使用的函数方法很多,例如:

#one应该是一个 selenium.webdriver.remote.webelement.WebElement 类的对象
one.text
one.get attribute('href')
one.tag name
one.id
...

之前曾对Selenium的基本使用做过简单的说明,有了网站交互(而不是典型爬虫程序避开浏览器界面的策略)还能够完成很多测试工作,如找出异常表单、HTML排版错误、页面交互问题。

目录
相关文章
|
3月前
|
Web App开发 前端开发
Selenium WebDriver
【8月更文挑战第9天】
49 7
|
3月前
|
JavaScript
[selenium]等待
[selenium]等待
|
4月前
|
Python
安装selenium
安装selenium
37 0
|
6月前
|
Web App开发 IDE 测试技术
Selenium WebDriver使用
Selenium WebDriver使用
50 1
|
6月前
|
Java 测试技术 持续交付
深入理解与应用Selenium WebDriver进行自动化测试
【4月更文挑战第25天】 在现代软件开发过程中,自动化测试已成为确保产品质量和加速市场发布的关键步骤。Selenium WebDriver作为业界广泛采用的自动化测试工具之一,提供了一种灵活且高效的方式来模拟用户与Web应用程序交互。本文将探讨Selenium WebDriver的核心概念、架构以及实际应用中的技巧和最佳实践。通过深入分析其工作原理及常见问题解决方案,旨在帮助测试工程师提升测试效率,确保测试结果的准确性和可靠性。
82 1
|
6月前
|
Web App开发 Shell Python
|
Web App开发 Java 测试技术
selenium-介绍和安装
selenium-介绍和安装
|
12月前
|
Web App开发 前端开发 JavaScript
selenium使用总结
selenium使用总结
54 0
|
Web App开发 前端开发 JavaScript
Selenium Webdriver 简易教程
Selenium Webdriver 简易教程
122 0