新版本的selenium已经明确警告将不支持PhantomJS,建议使用headless的Chrome或FireFox。
两者使用方式非常类似,基本步骤为:
- 下载驱动
- 创建选项,设定headless
- 创建WebDriver,指定驱动位置和选项
- 对URL发起请求,获得结果,进行解析
Chrome
驱动的下载路径为:https://chromedriver.storage.googleapis.com/index.html
接下来创建选项并设定headless:
1
2
|
options = webdriver.ChromeOptions() options.set_headless() |
创建WebDriver,指定驱动位置和选项:
1
2
|
driver = webdriver.Chrome( 'D://chromedriver_win32//chromedriver' , chrome_options = options) |
发起请求,获得结果并进行解析:
1
2
3
4
|
driver.get( 'http://www.sohu.com/' ) time.sleep( 3 ) print (driver.page_source) driver.close() |
Firefox
驱动的下载路径为:https://github.com/mozilla/geckodriver
启动的步骤与Chrome一致,只不过使用的选项对象和创建的WebDriver对象略有不同。直接上源代码:
1
2
3
4
5
6
7
8
9
|
options = webdriver.FirefoxOptions() options.set_headless() driver = webdriver.Firefox( firefox_options = options, executable_path = 'D:/geckodriver-win64/geckodriver' ) driver.get( 'http://www.sohu.com/' ) time.sleep( 3 ) print (driver.page_source) driver.close() |
SELENIUM使用HEADLESS无头模式实现无界面运行
先导包:
1
|
from selenium.webdriver.chrome.options import Options |
加入如下配置:
1
2
3
4
5
6
7
|
chrome_options = Options() chrome_options.add_argument( '--window-size=1920,1080' ) # 设置窗口界面大小 chrome_options.add_argument( '--headless' ) driver = webdriver.Chrome(chrome_options = chrome_options) |
参考代码:
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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
|
from selenium import webdriver import time import multiprocessing from selenium.webdriver.chrome.options import Options class Zutuan(): def __init__( self ): """打开浏览器""" self .chrome_options = Options() self .chrome_options.add_argument( '--window-size=1920,1080' ) self .chrome_options.add_argument( '--headless' ) self .driver = webdriver.Chrome(chrome_options = self .chrome_options) def open_zutuan( self , url): """传入组团url""" self .driver.get(url) #self.driver.maximize_window() self .driver.refresh() #time.sleep(0.01) self .driver.implicitly_wait( 30 ) # todo implicitly隐式等待,等待元素可见 def option_element( self , user, password): """xpath定位元素""" self .driver.find_element_by_xpath( '//div[@class="login a"]/i' ).click() time.sleep( 0.01 ) self .driver.find_element_by_xpath( '//div[@class="a-title"]' ).click() self .driver.find_element_by_xpath( '//input[@type="text" or @class="userName"]' ).send_keys(user) self .driver.find_element_by_xpath( '//input[@type="password"]' ).send_keys(password) self .driver.find_element_by_xpath( '//div[@class="button"]' ).click() time.sleep( 1 ) self .driver.refresh() def select_commodity( self , content): """搜索组团商品""" # TODO self.content实例属性传给下面的方法使用,如果想把值给下面的方法用,添加实例属性解决 self .content = content self .driver.find_element_by_xpath( '//input[@type="text"]' ).send_keys(content) self .driver.find_element_by_xpath( '//div[@class="search"]' ).click() self .driver.refresh() #return content def result( self ): """判断搜索商品成功后的提示信息,断言页面是否成功""" if self .content in self .driver.page_source: #print(self.content) print ( '商品搜索成功,测试通过' ) else : print ( '商品搜索错误,测试失败' ) def closed( self ): """关闭浏览器""" time.sleep( 1 ) self .driver.quit() def run1(): # TODO 根据操作顺序,调用方法执行 zt = Zutuan() zt.open_zutuan( 'http://www.zutuan.cn/index.html#/' ) zt.option_element( '1489088761@qq.com' , 'mg123456' ) zt.select_commodity( '香蕉' ) zt.result() zt.closed() class View_details(Zutuan): """把商品添加为明星单品,""" def check_commodity( self , number): """进入商品详情页,点击添加明星单品""" self .driver.find_element_by_xpath( '//a[@target="_blank"]/img' ).click() self .driver.switch_to.window( self .driver.window_handles[ 1 ]) self .driver.find_element_by_xpath( '//div[@class="child start"]' ).click() self .driver.find_element_by_xpath( '//div[@class="el-dialog__body"]//input[@type="text"]' ).send_keys(number) self .driver.find_element_by_xpath( '//button[@type="button" and @class="el-button el-button--danger"]' ).click() time.sleep( 1 ) def result( self ): """重写父类方法,判断商品添加成功后的提示信息,断言页面是否成功""" if '添加成功' in self .driver.page_source: print ( '商品添加成功,测试通过' ) else : print ( '商品添加失败,测试失败' ) # 调用父类方法关闭 super ().closed() def run2(): vd = View_details() vd.open_zutuan( 'http://www.zutuan.cn/index.html#/' ) vd.option_element( '1489088761@qq.com' , 'mg123456' ) vd.select_commodity( '苹果' ) vd.check_commodity( 91628 ) vd.result() def main(): p1 = multiprocessing.Process(target = run1) p2 = multiprocessing.Process(target = run2) p1.start() p2.start() if __name__ = = '__main__' : main() |
到此这篇关于selenium设置浏览器为headless无头模式(Chrome和Firefox)的文章就介绍到这了,更多相关selenium 浏览器为headless无头模式内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!
原文链接:https://blog.csdn.net/piglite/article/details/86317485