Maison > interface Web > tutoriel CSS > Comment puis-je localiser efficacement les éléments HTML par classe CSS à l'aide de XPath ?

Comment puis-je localiser efficacement les éléments HTML par classe CSS à l'aide de XPath ?

DDD
Libérer: 2024-12-24 05:47:21
original
139 Les gens l'ont consulté

How Can I Efficiently Locate HTML Elements by CSS Class Using XPath?

Recherche d'éléments par classe CSS à l'aide de XPath

Dans le web scraping, il est souvent nécessaire de localiser les éléments HTML en fonction de leur classe CSS. XPath, un outil puissant pour naviguer dans les documents XML et HTML, fournit un moyen d'y parvenir.

Considérez une page HTML avec un élément div ayant une classe nommée « Test ». La requête XPath suivante peut être utilisée pour trouver cet élément :

//*[contains(@class, 'Test')]
Copier après la connexion

Cette requête sélectionne tous les éléments qui contiennent la classe "Test", quel que soit leur emplacement dans l'arborescence du document.

Pour optimiser les performances, vous pouvez affiner la recherche à des types d'éléments spécifiques, tels que les divs. Par exemple, la requête suivante limitera la recherche aux divs contenant la classe « Test » :

//div[contains(@class, 'Test')]
Copier après la connexion

Cependant, si vous avez des éléments avec des classes comme « Testvalue » ou « newTest », la requête ci-dessus correspondra eux aussi. Pour garantir une correspondance plus précise, vous pouvez utiliser une chaîne concaténée contenant un espace avant et après la classe "Test", comme suggéré par @Tomalak :

//div[contains(concat(' ', @class, ' '), ' Test ')]
Copier après la connexion

Cette requête ne correspondra qu'aux divs contenant le mot "Test" en tant que valeur de classe distincte.

Pour éliminer tout problème d'espace, vous pouvez également normaliser les espaces à l'aide de la fonction normalize-space, comme suggéré par @Terry :

//div[contains(concat(' ', normalize-space(@class), ' '), ' Test ')]
Copier après la connexion

Enfin, il est important de remplacer l'astérisque (*) dans ces requêtes par le nom de l'élément réel que vous souhaitez faire correspondre, sauf si vous souhaitez rechercher tous les éléments du document. Cela améliorera l'efficacité de la requête.

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.cn
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal