Maison > développement back-end > Tutoriel Python > Pourquoi le sélecteur CSS avec :contains() provoque-t-il \'InvalidSelectorException\' dans Selenium Python avec Firefox ?

Pourquoi le sélecteur CSS avec :contains() provoque-t-il \'InvalidSelectorException\' dans Selenium Python avec Firefox ?

Patricia Arquette
Libérer: 2024-10-18 21:57:03
original
270 Les gens l'ont consulté

Why Does CSS Selector with :contains() Cause

Sélecteur CSS invalide dans Selenium Python : "selenium.common.exceptions.InvalidSelectorException avec "span:contains('string')""

Lorsque vous utilisez Selenium Python avec Firefox, tenter de trouver un élément par sélecteur CSS avec la pseudo-classe :contains(), telle que "span:contains('Control panel')", peut entraîner une "InvalidSelectorException."

Raison :

La pseudo-classe :contains() n'est pas prise en charge par Firefox ou Chrome. Comme indiqué dans les numéros 987 et 1547, WebDriver a choisi de ne pas inclure la prise en charge des sélecteurs CSS de style Sizzle, qui incluaient :contains().

Solutions alternatives :

Au lieu de cela, envisagez d'utiliser tout autre attribut de la balise span, tel que :

element = "span[attribute_name=attribute_value]"
Copier après la connexion

Vous pouvez également utiliser des XPaths basés sur la structure arborescente du DOM :

  • Utiliser du texte ():

    element = my_driver.find_element_by_xpath("//span[text()='Control panel']")
    Copier après la connexion
  • Utilisation de contain():

    element = my_driver.find_element_by_xpath("//span[contains(.,'Control panel')]")
    Copier après la connexion
  • Utilisation de normalize-space():

    element = my_driver.find_element_by_xpath("//span[normalize-space()='Control panel']")
    Copier après la connexion

Ou, vous pouvez exploiter jQuery pour les sélecteurs CSS avec :contains() :

$('span:contains("Control panel")')
Copier après la connexion

Remarque : Les sélecteurs CSS avec :contains() sont n'est pas non plus pris en charge dans la console, mais jQuery écrase document.querySelector par sa propre implémentation, permettant leur utilisation.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal