这里提供了 Selenium WebDriver 中用于查找元素的两个方法:find_element()
和 find_elements()
。
find_element(by='id', value: Optional[str] = None) → selenium.webdriver.remote.webelement.WebElement
element = driver.find_element(By.ID, 'foo')
WebElement
,表示找到的单个元素。find_elements(by='id', value: Optional[str] = None) → List[selenium.webdriver.remote.webelement.WebElement]
elements = driver.find_elements(By.CLASS_NAME, 'foo')
List[selenium.webdriver.remote.webelement.WebElement]
,表示找到的元素列表。这两个方法可以根据不同的定位策略(如 By.ID、By.CLASS_NAME、By.XPATH 等)和对应的定位器条件来定位页面上的元素。通过这些方法,你可以在自动化测试脚本中准确地定位和操作页面上的元素。
需要注意的是,在调用这两个方法之前,你需要先创建一个 WebDriver 实例(例如 webdriver.Chrome()
),然后使用该实例调用这些方法来查找页面上的元素。
- from selenium import webdriver
- from selenium.webdriver.common.by import By
- from selenium.webdriver.support.ui import WebDriverWait
- from selenium.webdriver.support import expected_conditions as EC
-
- driver = webdriver.Chrome()
-
- try:
- driver.get("https://www.hao123.com/")
- # print('*****driver_type',type(driver)) # driver_type
- input_elements = driver.find_elements(By.TAG_NAME, "input")
- for input_element in input_elements:
- print(input_element.get_attribute("outerHTML"))
-
- print('*'*35)
-
- lielements = driver.find_elements(By.CSS_SELECTOR, "ul.boxhot li")
- for li in lielements:
- print(li.text)
-
- search_input = driver.find_element(By.CSS_SELECTOR, 'input[data-hook="searchInput"]')
- # print('*****search_input_type',type(search_input)) # search_input_type
- search_input.send_keys("Selenium库")
- search_button = driver.find_element(By.CSS_SELECTOR, 'input[data-hook="searchSubmit"]')
- search_button.click()
- handles = driver.window_handles
- print(type(handles))
- if len(handles) > 1:
- driver.switch_to.window(handles[1])
- # Wait for the search results to load completely
- WebDriverWait(driver, 10).until(EC.presence_of_element_located((By.CSS_SELECTOR, 'div[id="content_left"]')))
- finally:
- driver.quit()
-
- # In this updated version, we added the following imports:
- # from selenium.webdriver.support.ui import WebDriverWait
- # from selenium.webdriver.support import expected_conditions as EC
- # We then added a WebDriverWait statement to wait for the presence of a specific element in the search results page:
- # WebDriverWait(driver, 10).until(EC.presence_of_element_located((By.CSS_SELECTOR, 'div[class="search-list-item"]')))
- # This statement waits for up to 10 seconds for an element with the CSS selector 'div[class="search-list-item"]' to appear on the page.
- # Once the element appears, the script continues to execute.
-
- # Note that you may need to adjust the CSS selector or the wait time to suit your specific needs.
- # (By.CSS_SELECTOR, 'div[id="content_left"]'),
class By:selenium.webdriver.common.by.By
类中各个常量的具体定位策略及其说明。
下面是这些常量的含义和用法:
By.CLASS_NAME: 根据元素的 class name 属性进行定位。
By.CSS_SELECTOR: 根据 CSS 选择器进行定位。
By.ID: 根据元素的 id 属性进行定位。
By.LINK_TEXT: 根据链接文本进行定位,适用于 标签。
By.NAME: 根据元素的 name 属性进行定位。
By.PARTIAL_LINK_TEXT: 根据链接文本的部分匹配进行定位。
By.TAG_NAME: 根据元素的标签名进行定位。
By.XPATH: 根据 XPath 表达式进行定位。
这些定位策略可根据元素的不同属性或特征进行定位,以便在 WebDriver 中找到所需的元素。您可以根据实际情况选择合适的定位策略来定位元素。
定位策略主要用于 find_element()
和 find_elements()
方法中的 locator 参数。通过指定相应的定位策略和对应的值,您可以精确定位到要操作的元素。
- class By:
- """Set of supported locator strategies."""
-
- ID = "id"
- XPATH = "xpath"
- LINK_TEXT = "link text"
- PARTIAL_LINK_TEXT = "partial link text"
- NAME = "name"
- TAG_NAME = "tag name"
- CLASS_NAME = "class name"
- CSS_SELECTOR = "css selector"