How to Select Elements By Class in XPath?

In web scraping with Selenium, particularly when using Python, selecting elements by their class attributes is crucial. XPath offers a powerful way to target these elements, enhancing the precision of your web scraping tasks.

Quick Guide on XPath Class Selection

To select elements based on class names with XPath, use the @class attribute in your XPath expression. Here’s a simplified syntax:

//*[contains(@class, 'your-class-name')]

This method is effective for elements with multiple classes, where ‘your-class-name’ should be replaced with the actual class you’re targeting.

Example: Getting Elements by Class

Here’s a concise example showing how to select elements by class:

from selenium import webdriver

driver = webdriver.Chrome()


# Replace 'example-class' with the actual class name

elements = driver.find_elements_by_xpath("//*[contains(@class, 'example-class')]")

for element in elements:



This code initializes Selenium WebDriver, navigates to a webpage, selects elements by class, and prints their text. It’s a straightforward method for efficiently extracting data from web pages in your Python web scraping projects.


  • Ensure the webpage is fully loaded before selecting elements.
  • The contains function is case-sensitive, so match class names accurately.
  • For multiple classes, contains allows for flexible matching.
  • If targeting an element with multiple classes, remember that the order of classes in the @class attribute is not guaranteed. Focus on identifying a unique class name or combination of class names that reliably indicates the element you wish to select.

By mastering XPath class selection, you enhance your web scraping capabilities with Selenium, making your Python scripts more effective and precise in data extraction.

Other XPath related questions:

  1. How Does XPath Contains Work?

Ready to get started?