发布时间:2018-08-16 17:14:41编辑:Run阅读(13359)
Selenium使用代理IP&无头模式访问网站
很多防爬机制会自动检测ip访问的频率,超过设定的次数,就会被封,这个时候就需要使用代理ip来解决这个问题了
代码如下:
#!/usr/bin/env python # coding: utf-8 from selenium import webdriver class Proxy(object): def __init__(self): self.proxy_ip = 'http://代理ip地址:端口' self.browser = self.getbrowser() self.getpage(self.browser) def getbrowser(self): options = webdriver.ChromeOptions() # 设置代理 desired_capabilities = webdriver.DesiredCapabilities.INTERNETEXPLORER.copy() desired_capabilities['proxy'] = { "httpProxy": self.proxy_ip, # "ftpProxy": self.proxy_ip, # 代理ip是否支持这个协议 # "sslProxy": self.proxy_ip, # 代理ip是否支持这个协议 "noProxy": None, "proxyType": "MANUAL", "class": "org.openqa.selenium.Proxy", "autodetect": False } # 使用无头模式 options.add_argument('headless') browser = webdriver.Chrome(chrome_options=options, executable_path=r'D:\chromedriver_2.41\chromedriver.exe', desired_capabilities=desired_capabilities) return browser def getpage(self, browser): # 打开目标网站 browser.get("https://www.baidu.com") # 对整个页面进行截图 browser.save_screenshot('百度.png') # 打印网站的title信息 print(browser.title) # 检测代理ip是否生效 browser.get("http://httpbin.org/ip") # 获取当前所有窗口集合(list类型) --- 因为打开多个窗口 handles = browser.window_handles # 切换到最新的窗口 browser.switch_to_window(handles[-1]) # 打印新窗口网页的内容 print(browser.page_source) if __name__ == '__main__': Proxy()
运行程序,显示打印的是代理ip地址,则表示使用代理成功
还会自动截图
47604
45981
36908
34467
29079
25712
24565
19713
19245
17756
5564°
6155°
5690°
5737°
6703°
5482°
5484°
5988°
5965°
7295°