find_element属于定位元素的一种方法,包含了常用的定位方法。
在使用find——element 时 一定要导入相关的包,不然会报错
from selenium import webdriver# 一定要导入这个包from selenium.webdriver.common.by import By
def find_element(self, by=By.ID, value=None) -> WebElement: """ Find an element given a By strategy and locator. :Usage: :: element = driver.find_element(By.ID, 'foo') :rtype: WebElement """ if isinstance(by, RelativeBy): elements = self.find_elements(by=by, value=value) if not elements: raise NoSuchElementException(f"Cannot locate relative element with: {by.root}") return elements[0] if by == By.ID: by = By.CSS_SELECTOR value = '[id="%s"]' % value elif by == By.CLASS_NAME: by = By.CSS_SELECTOR value = ".%s" % value elif by == By.NAME: by = By.CSS_SELECTOR value = '[name="%s"]' % value return self.execute(Command.FIND_ELEMENT, { 'using': by, 'value': value})['value']
以百度页面为例:
选中搜索框,右键点击检查
本篇一切方法都是基于此。
选择要使用的浏览器和搜索网站,以Chrome浏览器和百度为例
driver = webdriver.Chrome()driver.get("http://www.baidu.com/")
以 id 为例
从上面的图可以看到,id 为 “kw”
#搜索框 id 为 kw,向搜索框发送“脱口秀大会进行搜索”driver.find_element(By.ID, 'kw').send_keys('脱口秀大会')#百度一下的 id 为 su,然后点击进行搜索driver.find_element(By.ID, 'su').click()#关闭浏览器driver.close()
然后运行浏览器就可以进行搜索了 ,使用完一定要使用driver.close()进行关闭
如果想要界面待得时间长一点,还可以导入包
#包import time#8秒后关闭浏览器time.sleep(8)driver.close()
除了id外,下面这些都可以用来进行查找,用来查找的一定要是唯一的,如果不唯一就会报错,浏览器也会停止在网页首页,不进行查找,id具有唯一性。
4.用XPATH 和 CSS_SELECTOR查找的本质都是 id查找,所以也是唯一的。
在上面查找的基础上,点击所要查找的id行,右键复制里
使用同上
# driver.find_element(By.XPATH,'//*[@id="kw"]').send_keys("创造101")# driver.find_element(By.XPATH, '//*[@id="su"]').click()driver.find_element(By.CSS_SELECTOR, '#kw').send_keys("qq")driver.find_element(By.CSS_SELECTOR, '#su').click()
来源地址:https://blog.csdn.net/qq_54426859/article/details/125896024