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,无头模式
0
投稿

猜你喜欢

  • 使用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
  • asp之家 网络编程 m.aspxhome.com