最近在使用tkinter来开发一个GUI程序,用到了selenium的headless模式。代码调试妥当,准备用pyinstaller打包成exe文件,却发现在pycharm里面一切正常,打包后会弹出一个黑框,影响体验:

有的同学还会有类似以下日志

DevTools listening on ws://127.0.0.1:12345...........

搜索一番之后大概发现了网上说的2种方案

pyinstaller 使用 --windowed参数修改.../Lib/sit-packages/selenium/webdriver/common/service.py的源码,将76行的creationflags改为一个神秘数字134217728(其实就是0x8000000)

长话短说,我本来就已经使用了-w参数编译,所以方法1不是我遇到的问题的原因,方法2才是。但是这么写比较粗鲁,更好的方法应该是写一个子类继承Service类(无奈selenium官方不提供修改该参数的公有方法)。

原来的写法(会弹窗)

from selenium.webdriver import ChromeOptions, Chrome

from selenium.webdriver.chrome.service import Service

from webdriver_manager.chrome import ChromeDriverManager

def initial_driver():

my_options = ChromeOptions()

my_options.add_argument('--headless')

my_options.add_experimental_option('excludeSwitches', ['enable-logging'])

return Chrome(options=my_options, service=Service(ChromeDriverManager().install()))

改为这样(不弹窗):

from selenium.webdriver import ChromeOptions, Chrome

from selenium.webdriver.chrome.service import Service

from webdriver_manager.chrome import ChromeDriverManager

class MyService(Service):

def __init__(self, executable_path: str,

port: int = 0, service_args=None,

log_path: str = None, env: dict = None):

super(Service, self).__init__(

executable_path,

port,

service_args,

log_path,

env,

"Please see https://chromedriver.chromium.org/home")

self.creationflags = 0x8000000

def initial_driver():

my_options = ChromeOptions()

my_options.add_argument('--headless')

my_options.add_experimental_option('excludeSwitches', ['enable-logging'])

return Chrome(options=my_options, service=MyService(ChromeDriverManager().install()))

其中,下面这句的作用就是关闭“DevTools listening on ws://127.0.0.1:12345...........”的日志输出

my_options.add_experimental_option('excludeSwitches', ['enable-logging'])

参考文章

评论可见,请评论后查看内容,谢谢!!!评论后请刷新页面。