Python:禁用Selenium Google ChromeDri中的图像

2024-04-28 12:36:04 发布

您现在位置:Python中文网/ 问答频道 /正文

我花了很多时间寻找这个。 在一天结束的时候,我把一些答案组合在一起,这样就行了。我分享我的答案,如果有人修改或提供一个更简单的方法,我会很感激。

1 Disable images in Selenium Google ChromeDriver中的答案在Java中有效。所以我们应该在Python中做同样的事情:

opt = webdriver.ChromeOptions()
opt.add_extension("Block-image_v1.1.crx")
browser = webdriver.Chrome(chrome_options=opt)

2-但是下载“Block-image_v1.1.crx”有点棘手,因为没有直接的方法。为了这个目的,而不是去:https://chrome.google.com/webstore/detail/block-image/pehaalcefcjfccdpbckoablngfkfgfgj

你可以去http://chrome-extension-downloader.com/ 并在那里粘贴扩展名url,以便能够下载扩展名文件。

3-然后您将能够使用上述代码和您下载的扩展文件的路径。


Tags: 文件方法答案imagecomextension时间chrome
3条回答

每个人都可能想到另一种方法来访问chrome://settings,然后使用selenium进行设置,我这样做只是为了启发好奇心,但是当你遇到超过3个结合了动态内容的影子根元素时,很明显这是一种混淆并使其无法自动化的方法,尽管听起来至少理论上可能这种方法看起来更像是一个死胡同,我将用示例代码来回答这个问题,只是为了纯粹的学习目的,以宣传那些想参加挑战的人。。由于阴影根和动态更改,不仅很难找到内容设置,当您发现按钮此时不可单击。

driver = webdriver.Chrome()


def expand_shadow_element(element):
  shadow_root = driver.execute_script('return arguments[0].shadowRoot', element)
  return shadow_root

driver.get("chrome://settings")
root1 = driver.find_element_by_tag_name('settings-ui')
shadow_root1 = expand_shadow_element(root1)

root2 = shadow_root1.find_element_by_css_selector('[page-name="Settings"]')
shadow_root2 = expand_shadow_element(root2)

root3 = shadow_root2.find_element_by_id('search')
shadow_root3 = expand_shadow_element(root3)

search_button = shadow_root3.find_element_by_id("searchTerm")
search_button.click()

text_area = shadow_root3.find_element_by_id('searchInput')
text_area.send_keys("content settings")

root0 = shadow_root1.find_element_by_id('main')
shadow_root0_s = expand_shadow_element(root0)


root1_p = shadow_root0_s.find_element_by_css_selector('settings-basic-page')
shadow_root1_p = expand_shadow_element(root1_p)


root1_s = shadow_root1_p.find_element_by_css_selector('settings-privacy-page')
shadow_root1_s = expand_shadow_element(root1_s)

content_settings_div = shadow_root1_s.find_element_by_css_selector('#site-settings-subpage-trigger')
content_settings = content_settings_div.find_element_by_css_selector("button")
content_settings.click()

Java: 有了这个Chrome和Firefox,就可以加载图像。语法不同,但参数上的字符串相同。

    chromeOptions = new ChromeOptions();
    HashMap<String, Object> images = new HashMap<String, Object>();
    images.put("images", 2);
    HashMap<String, Object> prefs = new HashMap<String, Object>();
    prefs.put("profile.default_content_setting_values", images);
    chromeOptions.setExperimentalOption("prefs", prefs);
    driver=new ChromeDriver(chromeOptions);

    firefoxOpt = new FirefoxOptions();
    FirefoxProfile profile = new FirefoxProfile();
    profile.setPreference("permissions.default.image", 2);
    firefoxOpt.setProfile(profile);

下面是禁用图像的另一种方法:

from selenium import webdriver

chrome_options = webdriver.ChromeOptions()
prefs = {"profile.managed_default_content_settings.images": 2}
chrome_options.add_experimental_option("prefs", prefs)
driver = webdriver.Chrome(chrome_options=chrome_options)

我在下面找到的:

http://nullege.com/codes/show/src@o@s@osintstalker-HEAD@fbstalker1.py/56/selenium.webdriver.ChromeOptions.add_experimental_option

相关问题 更多 >