環境:
OS:Windows 10 17134
Python:3.4.4
Selenium:3.13.0
Browser:68.0.3440.84(正式版本) (64 位)
ChromeDriver:2.41
腳本內容:
# -*- coding: utf-8 -*-
"""
測試 selenium webdriver
"""
import time
from selenium import webdriver
def test():
driver = webdriver.Chrome()
driver.get('http://www.google.com/xhtml')
time.sleep(5) # Let the user actually see something!
search_box = driver.find_element_by_name('q')
search_box.send_keys('ChromeDriver')
search_box.submit()
time.sleep(5) # Let the user actually see something!
driver.quit()
if __name__ == '__main__':
test()
現象:
腳本正常執行,腳本功能也執行正確,但是命令行輸出有錯誤信息。
錯誤信息如下:
[17672:21484:0802/155619.485:ERROR:install_util.cc(603)] Failed to read HKLM\SOFTWARE\Policies\Google\Chrome\MachineLevelUserCloudPolicyEnrollmentToken: 系統找不到指定
的文件。 (0x2)
網上提供的各種解決方案:
1.升級 selenium 版本到最新 - 已確認,無效;
2.chromium 的 bug 報告說讓升級 chrome 到 68.0.3433.0 及以上,並使用對應版本的 ChromeDriver - 已確認,無效;
3.ChromeDriver 使用說明裏建議「(Python only) include the path to ChromeDriver when instantiating webdriver.Chrome」- 已確認,無效;
4.命令行提權運行「reg add HKLM\SOFTWARE\Policies\Google\Chrome /v MachineLevelUserCloudPolicyEnrollmentToken /t REG_SZ」,添加報錯信息中提示的註冊表值 - 已確認,有效。
結論:
1.可以手動在 regedit 中增加這個註冊表值;
2.可以通過 .reg 文件增加這個註冊表值;
3.可以使用命令行增加這個註冊表值。
參考網站:
https://github.com/SeleniumHQ/selenium/issues/5966
https://bugs.chromium.org/p/chromium/issues/detail?id=848232
http://chromedriver.chromium.org/getting-started