selenium 介绍和安装 爬虫过程中,各种反爬机制让人头疼。由于动态网页的存在,明明浏览器看得见可以点击的东西,却不能直接通过 requests 请求得到。非要绕很多弯才能获取我们想要的数据。有的请求还要携带 cookie 和一些乱七八糟的字符串。
selenium 模块就是为了帮我们解决这些困扰而诞生的。
selenium 是一种基于浏览器的自动化的模块。
自动化的含义是,可以通过代码指定一些列的行为动作,然后将其作用到浏览器中。
因为 selenium 本身就是基于浏览器的,所以几乎不会受到反爬机制的束缚。
selenium 的安装:
selenium 和爬虫之间的关联
便捷的捕获到任意形式动态加载的数据(可见即可得)
实现模拟登录
selenium 虽然能给我们带来很大的便捷,但是却有一个显著的缺点 —— 效率太低。因为每次爬取信息,都要打开浏览器。
在使用 selenium 之前,我们需要下载各种浏览器的驱动,注意驱动版本要和当前使用的浏览器版本相符合。
谷歌驱动下载:http://chromedriver.storage.googleapis.com/index.html
驱动下载好后,最好保存在环境变量中存在的文件夹中,比如 Python 安装目录的 bin 目录。这样,我们在使用 selenium 的时候,就不必每次都指定驱动了。
这里的示例,我把谷歌浏览器驱动放在了工作目录中,每次使用都要指定驱动的位置。
selenium 的基本使用流程如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 from selenium import webdriverfrom time import sleepfrom lxml import etreebro = webdriver.Chrome(executable_path='./chromedriver.exe' ) bro.get('https://www.jd.com' ) search_box = bro.find_element_by_xpath('//input[@id="key"]' ) search_box.send_keys('iphone X' ) search_btn = bro.find_element_by_xpath('//button[@aria-label="搜索"]' ) search_btn.click() sleep(2 ) bro.execute_script('window.scrollTo(0, document.body.scrollHeight)' ) sleep(2 ) bro.quit()
再看一个处理百度网页的例子:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 from selenium import webdriverfrom time import sleepdriver = webdriver.Chrome(r'./chromedriver.exe' ) driver.get("http://www.baidu.com" ) driver.find_elements_by_link_text('设置' )[0 ].click() sleep(2 ) driver.find_elements_by_link_text('搜索设置' )[0 ].click() sleep(2 ) m = driver.find_element_by_id('nr' ) sleep(2 ) m.find_element_by_xpath('//*[@id="nr"]/option[3]' ).click() m.find_element_by_xpath('.//option[3]' ).click() sleep(2 ) driver.find_elements_by_class_name("prefpanelgo" )[0 ].click() sleep(2 ) driver.switch_to.alert.accept() sleep(2 ) driver.find_element_by_id('kw' ).send_keys('美女' ) sleep(2 ) driver.find_element_by_id('su' ).click() sleep(2 ) driver.find_element_by_xpath('//*[@id="1"]/div[1]/a[1]/img' ).click() sleep(3 ) driver.quit()
我们从前爬取过药监局的网页,那个网页时动态生成的。当时我们是通过浏览器的抓包工具,找到获取数据的请求,从而实现了页面信息的抓取。
如果使用 selenium,抓取动态网页将变得很容易。
需求:抓取药监局页面前三页所有企业名称信息
网址 url:http://125.35.6.84:81/xk/
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 url = 'http://125.35.6.84:81/xk/' bro = webdriver.Chrome(executable_path='./chromedriver' ) bro.get(url) page_text_list = [] sleep(2 ) page_text_list.append(bro.page_source) for i in range (2 ): next_btn = bro.find_element_by_id('pageIto_next' ) next_btn.click() sleep(1 ) page_text_list.append(bro.page_source) for page_text in page_text_list: tree = etree.HTML(page_text) text_list = tree.xpath('//ul[@id="gzlist"]//dl//text()' ) for text in text_list: print(text) sleep(2 ) bro.quit()
动作链 ActionChains 有时候,我们除了点击操作之外,还会有一些比如拖动等操作。这时候,就需要用到动作链。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 bro = webdriver.Chrome(executable_path='./chromedriver.exe' ) bro.get('https://www.runoob.com/try/try.php?filename=jqueryui-api-droppable' ) bro.switch_to.frame('iframeResult' ) div_tag = bro.find_element_by_id('draggable' ) action = webdriver.ActionChains(bro) action.click_and_hold(div_tag) for i in range (4 ): action.move_by_offset(10 , 15 ).perform() sleep(0.5 ) sleep(2 ) bro.quit()
让 selenium 规避检测 虽然 selenium 很强大,但依然有可能会漏出马脚,让人家检测出我们是在使用 selenium 发起的浏览器请求。有的网站会检测请求是否为 selenium 发起,如果是的话则让该次请求失败。
规避检测的方法是让 selenium 接管 chrome 浏览器。
实现步骤
必须将你电脑中安装的谷歌浏览器的主程序所在的目录找到,且将目录添加到环境变量中。
打开 cmd,在命令行中输入命令:
1 chrome.exe --remote-debugging-port=9222 --user-data-dir="一个空文件夹的目录"
指定执行结束后,会打开你本机安装好的谷歌浏览器。
执行如下代码:可以使用下述代码接管步骤 2 打开的真实的浏览器
1 2 3 4 5 6 7 8 9 10 from selenium import webdriverfrom selenium.webdriver.chrome.options import Options chrome_options = Options() chrome_options.add_experimental_option("debuggerAddress" , "127.0.0.1:9222" ) chrome_driver = "./chromedriver.exe" driver = webdriver.Chrome(executable_path=chrome_driver,chrome_options=chrome_options) print(driver.title)
无头浏览器 我们看到,每次执行 selenium 代码,都要打开浏览器窗口,然后亲眼看着它操作。有的时候,如果不小心把鼠标放到浏览器的窗口里面,还有可能会影响到自动化程序的正常运行。
无头浏览器,就是将浏览器的页面隐藏起来,我们看不见它的操作。那么就不会在每次允许 selenium 代码的时候跳出窗口来犯我们。我们也不会因为误操作而影响程序的运行。
常用的无头浏览器有两个:
谷歌无头浏览器(推荐)
phantomJs(停止维护)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 from selenium import webdriverfrom selenium.webdriver.chrome.options import Optionsimport time chrome_options = Options() chrome_options.add_argument('--headless' ) chrome_options.add_argument('--disable-gpu' ) browser = webdriver.Chrome(executable_path='./chromedriver' , chrome_options=chrome_options) url = 'https://www.baidu.com/' browser.get(url) time.sleep(3 ) browser.save_screenshot('baidu.png' ) print(browser.page_source) browser.quit()