Selenium Chrome无法看到浏览器日志InvalidArgumentException

Sha*_*ady 0 python selenium google-chrome selenium-chromedriver selenium-webdriver

在使用python的硒WebDriver打开网站后,我试图获取HTTP状态代码,我看到无法获取HTTP状态代码,所以唯一的方法是从那里获取网络日志并获取HTTP状态代码

所以我正在尝试打印硒中的日志,但这给了我InvalidArgumentException

from selenium import webdriver
from selenium.webdriver.common.desired_capabilities import DesiredCapabilities

# enable browser logging
d = DesiredCapabilities.CHROME
d['loggingPrefs'] = { 'performance':'ALL' }

driver = webdriver.Chrome(desired_capabilities=d)

# load the desired webpage
driver.get('http://foo.com')

# print messages
for entry in driver.get_log('performance'):
    print(entry)
Run Code Online (Sandbox Code Playgroud)

这是运行后的错误

InvalidArgumentException                  Traceback (most recent call last)
<ipython-input-13-8480733201dc> in <module>
     12 
     13 # print messages
---> 14 for entry in driver.get_log('performance'):
     15     print(entry)

c:\users\slimshady\appdata\local\programs\python\python37-32\lib\site-packages\selenium\webdriver\remote\webdriver.py in get_log(self, log_type)
   1260             driver.get_log('server')
   1261         """
-> 1262         return self.execute(Command.GET_LOG, {'type': log_type})['value']

c:\users\slimshady\appdata\local\programs\python\python37-32\lib\site-packages\selenium\webdriver\remote\webdriver.py in execute(self, driver_command, params)
    319         response = self.command_executor.execute(driver_command, params)
    320         if response:
--> 321             self.error_handler.check_response(response)
    322             response['value'] = self._unwrap_value(
    323                 response.get('value', None))

c:\users\slimshady\appdata\local\programs\python\python37-32\lib\site-packages\selenium\webdriver\remote\errorhandler.py in check_response(self, response)
    240                 alert_text = value['alert'].get('text')
    241             raise exception_class(message, screen, stacktrace, alert_text)
--> 242         raise exception_class(message, screen, stacktrace)
    243 
    244     def _value_or_default(self, obj, key, default):

InvalidArgumentException: Message: invalid argument: log type 'performance' not found
  (Session info: chrome=75.0.3770.80)
Run Code Online (Sandbox Code Playgroud)

我在这里可能做错了什么?

mbi*_*bit 7

chrome 75 和它的 chromedriver 有同样的问题,将 'w3c' 设置为 False 解决了这个问题:

from selenium import webdriver
from selenium.webdriver.common.desired_capabilities import DesiredCapabilities
from selenium.webdriver.chrome.options import Options

d = DesiredCapabilities.CHROME
d['loggingPrefs'] = { 'performance':'ALL' }

chrome_options = Options()
chrome_options.add_experimental_option('w3c', False)

driver = webdriver.Chrome(desired_capabilities=d, options=chrome_options)
Run Code Online (Sandbox Code Playgroud)

  • 在未来版本的 Chrome 中将删除在非 W3C 模式下运行的功能 (2认同)

Ale*_*ach 5

根据Chrome驱动程序75 的发行说明中的规定,功能loggingPrefsgoog:loggingPrefs按照W3C标准的要求重命名为。因此,设置功能的代码应该进行调整,至少由于日志捕获原因,没有必要退回到非w3c模式。

d['goog:loggingPrefs'] = { 'performance':'ALL' }
Run Code Online (Sandbox Code Playgroud)