selenium设置浏览器为headless无头模式(Chrome和Firefox)
作者:哦... 时间:2023-02-19 14:09:08
新版本的selenium已经明确警告将不支持PhantomJS,建议使用headless的Chrome或FireFox。
两者使用方式非常类似,基本步骤为:
下载驱动
创建选项,设定headless
创建WebDriver,指定驱动位置和选项
对URL发起请求,获得结果,进行解析
Chrome
驱动的下载路径为:https://chromedriver.storage.googleapis.com/index.html
接下来创建选项并设定headless:
options = webdriver.ChromeOptions()
options.set_headless()
创建WebDriver,指定驱动位置和选项:
driver = webdriver.Chrome(
'D://chromedriver_win32//chromedriver', chrome_options=options)
发起请求,获得结果并进行解析:
driver.get('http://www.sohu.com/')
time.sleep(3)
print(driver.page_source)
driver.close()
Firefox
驱动的下载路径为:https://github.com/mozilla/geckodriver
启动的步骤与Chrome一致,只不过使用的选项对象和创建的WebDriver对象略有不同。直接上源代码:
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无头模式实现 * 面运行
先导包:
from selenium.webdriver.chrome.options import Options
加入如下配置:
chrome_options = Options()
chrome_options.add_argument('--window-size=1920,1080') # 设置窗口界面大小
chrome_options.add_argument('--headless')
driver = webdriver.Chrome(chrome_options=chrome_options)
参考代码:
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()
来源:https://blog.csdn.net/piglite/article/details/86317485
标签:selenium,无头模式


猜你喜欢
使用Python实现BT种子和磁力链接的相互转换
2022-12-21 04:33:25
使用Python画股票的K线图的方法步骤
2021-03-24 06:54:24

Python标准库pathlib操作目录和文件
2021-08-18 02:24:57

Python多线程threading join和守护线程setDeamon原理详解
2022-05-25 18:09:39
python自动化测试之Selenium详解
2022-07-16 12:24:44

cv2.getStructuringElement()函数及开、闭、腐蚀、膨胀原理讲解
2023-08-24 23:07:23

javascript json字符串到json对象转义问题
2023-07-02 05:18:22
Python连接Hadoop数据中遇到的各种坑(汇总)
2023-09-13 20:16:34
详解Python list和numpy array的存储和读取方法
2022-05-04 05:58:10

使用MYSQL TIMESTAMP字段进行时间加减运算问题
2024-01-13 12:24:29
python sklearn常用分类算法模型的调用
2021-06-18 11:42:25
Django搭建MySQL主从实现读写分离
2024-01-14 08:13:09
python实现随机漫步方法和原理
2023-06-26 19:32:02

python实现canny边缘检测
2022-03-05 00:24:08

对IPython交互模式下的退出方法详解
2021-08-04 10:03:11
最简洁的SQL多重查询的解决方案
2005-09-12 16:31:00
细化解析:SQL Server数据库的集群设计
2009-02-05 15:59:00
浅谈Python 中的复数问题
2023-04-22 17:02:11

使用Pyinstaller转换.py文件为.exe可执行程序过程详解
2022-11-30 22:43:40

关于 Python json中load和loads区别
2021-04-24 20:30:51