- 注意:由于Selenium3 与Selenium4 版本改动比较大。本次教程着重讲解 Selenium4 但并会与Selenium3 的一些方法进行对比。
文章目录
- 一、单个元素定位方法实战
- 1.1 通过 find_element_by_id() 或 find_element(By.ID, value)定位
- 1.2 通过 find_element_by_name() 或 find_element(By.NAME, value)定位
- 1.3 通过 find_element_by_class_name() 或 find_element(By.NAME, value)定位
- 1.4 通过 find_element_by_xpath() 或 find_element(By.XPATH, value)定位
- 1.5 通过 find_element_css_selector() 或find_element(By.CSS_SELECTOR, value)定位
- 二、多个元素定位方法实战
- 三、JavaScript 与 JQuery 定位方法实战
- 总结:Selenium4 定位划重点
WebDrive 包含多种定位方法,常用定位方法(id、name、class、link_text、partial_link_text、tag、xpath、css)等。
一、单个元素定位方法实战
本章用 www.baidu.com 举例
1.1 通过 find_element_by_id() 或 find_element(By.ID, value)定位
注意: find_element_by_id()属于selenium3 定位方法,find_element(By.ID, value)属于selenium4 定位方法
from selenium import webdriver
from selenium.webdriver.common.by import By
import time
# 获取浏览器驱动 注意:Chrome() Firefox() 必须用大写开头
driver = webdriver.Chrome()
# 访问 Web 地址
driver.get("http://www.baidu.com/")
# 使用 find_element(By.ID, value) 方法定位
driver.find_element(By.ID, 'kw').send_keys("Python Web自动化测试")
# 点击百度一下
driver.find_element(By.ID,'su').click()
# driver.close()关闭驱动,driver.quit()退出驱动,开发中一般建议使用driver.quit()
time.sleep(5)
driver.quit()
1.2 通过 find_element_by_name() 或 find_element(By.NAME, value)定位
注意: find_element_by_name()属于selenium3 定位方法,find_element(By.NAME, value)属于selenium4 定位方法
from selenium import webdriver
import time
from selenium.webdriver.common.by import By
# 打开浏览器
driver = webdriver.Chrome()
# 请求百度搜索
driver.get('http://www.baidu.com/')
# 使用 find_element(By.NAME, value) 方法定位
driver.find_element(By.NAME,'wd').send_keys('Python Web自动化测试')
# 点击百度一下 (百度一下没有找到name方法定位元素,使用id定位代替)
driver.find_element(By.ID,'su').click()
time.sleep(5)
# driver.close()关闭驱动,driver.quit()退出驱动,开发中一般建议使用driver.quit()
driver.quit()
1.3 通过 find_element_by_class_name() 或 find_element(By.NAME, value)定位
注意: find_element_by_name()属于selenium3 定位方法,find_element(By.NAME, value)属于selenium4 定位方法
from selenium import webdriver
import time
from selenium.webdriver.common.by import By
# 打开浏览器
driver = webdriver.Chrome()
# 请求百度搜索
driver.get('http://www.baidu.com/')
# 使用 find_element(By.CLASS_NAME, value) 方法定位
driver.find_element(By.CLASS_NAME,'s_ipt').send_keys('Python Web自动化测试')
# 点击百度一下 (使用的CLASS_NAME定位)
driver.find_element(By.CLASS_NAME,'s_btn').click()
time.sleep(5)
# driver.close()关闭驱动,driver.quit()退出驱动,开发中一般建议使用driver.quit()
driver.quit()
1.4 通过 find_element_by_xpath() 或 find_element(By.XPATH, value)定位
注意: find_element_by_xpath()属于selenium3 定位方法,find_element(By.XPATH, value)属于selenium4 定位方法
from selenium import webdriver
import time
from selenium.webdriver.common.by import By
# 打开浏览器
driver = webdriver.Chrome()
# 请求百度搜索
driver.get('http://www.baidu.com/')
# 使用 find_element(By.XPATH, value) ID 定位方法
"""
'//input[@id="kw"]'可以替换 '//*[@id="kw"]'
* 号是通配符 这里是用的 xpath id 定位可以替换成 name 、class 等定位方式
"""
driver.find_element(By.XPATH,'//input[@id="kw"]').send_keys('Python Web自动化测试')
# 点击百度一下 (使用的XPATH ID 定位)
driver.find_element(By.XPATH,'//input[@id="su"]').click()
time.sleep(5)
# driver.close()关闭驱动,driver.quit()退出驱动,开发中一般建议使用driver.quit()
driver.quit()
1.4.1 扩充 xpath 定位知识点
在 selenium 使用过程中最多的就是 id 精准定位其次就是 name相对定位,用的最频繁的就是xpath 定位方法
xpath 定位代码:xpath 灵活多变,很多组合请自行摸索,请根据例子举一反三。
"""
这里我只写替代方法,不写详细代码
"""
# 使用xpath + 通配符 * + name 定位方法
driver.find_element(By.XPATH,'//*[@name="wd"]').send_keys('Python Web自动化测试')
# 使用xpath + input + name 定位方法
driver.find_element(By.XPATH,'//input[@name="wd"]').send_keys('Python Web自动化测试')
# 使用xpath + class + class定位方法
driver.find_element(By.XPATH,'//input[@class="s_ipt"]').send_keys('Python Web自动化测试')
# 使用xpath + from + id + 多层级定位 (这种定位方式对路径字符正确性要求极高,建议安装一些浏览器插件辅助)
driver.find_element(By.XPATH,'//form[@id="form"]/span/input').send_keys('Python Web自动化测试')
1.5 通过 find_element_css_selector() 或find_element(By.CSS_SELECTOR, value)定位
注意: find_element_css_selector()属于selenium3 定位方法,find_element(By.CSS_SELECTOR, value)属于selenium4 定位方法
from selenium import webdriver
import time
from selenium.webdriver.common.by import By
"""
find_element(By.CSS_SELECTOR,value) 第一种定位方法
"""
# 打开浏览器
driver = webdriver.Chrome()
# 请求百度搜索
driver.get('http://www.baidu.com/')
# 使用 find_element(By.CSS_SELECTOR, value) 方法定位
"""
input#kw input+id 名称定位
input#su input+id 名称定位
"""
driver.find_element(By.CSS_SELECTOR, 'input#kw').send_keys('Python Web自动化测试')
# 点击百度一下 (使用的CSS_SELECTOR定位)
driver.find_element(By.CSS_SELECTOR, 'input#su').click()
time.sleep(5)
# driver.close()关闭驱动,driver.quit()退出驱动,开发中一般建议使用driver.quit()
driver.quit()
"""
find_element(By.CSS_SELECTOR,value) 第二种定位方法
"""
# 打开浏览器
driver = webdriver.Chrome()
# 请求百度搜索
driver.get('http://www.baidu.com/')
# 使用 find_element(By.CSS_SELECTOR, value) 方法定位
"""
form#form>span>input 模糊定位
form#form>span>input#su input+id 名称精准定位
"""
driver.find_element(By.CSS_SELECTOR, 'form#form>span>input').send_keys('Python Web自动化测试')
# 点击百度一下 (使用的CSS_SELECTOR定位)
driver.find_element(By.CSS_SELECTOR, 'form#form>span>input#su').click()
time.sleep(5)
# driver.close()关闭驱动,driver.quit()退出驱动,开发中一般建议使用driver.quit()
driver.quit()
二、多个元素定位方法实战
2.1 通过 find_elements_css_selector() 或find_elements(By.CSS_SELECTOR, value)定位
注意: find_elements_css_selector()属于selenium3 定位方法,find_elements(By.CSS_SELECTOR, value)属于selenium4 定位方法
from selenium import webdriver
import time
from selenium.webdriver.common.by import By
# 打开Chrome浏览器
driver= webdriver.Chrome()
# 请求 aol 邮箱注册
driver.get('https://login.aol.com/account/create')
# 使用 find_elements(By.CSS_SELECTOR, value)+索引 方法定位
driver.find_elements(By.CSS_SELECTOR,"input[type='text']")[0].send_keys("Tong")
driver.find_elements(By.CSS_SELECTOR,"input[type='text']")[1].send_keys("Hua")
time.sleep(5)
# driver.close()关闭驱动,driver.quit()退出驱动,开发中一般建议使用 driver.quit()
driver.quit()
注意:这段代码是整个页面有多个相同的 input 标签,而且 input 标签的 type 属性值都是 text 一样的。可以用个Python 索引来定位元素 。[0]、[1] …… 代表索引
2.2 通过 find_elements_by_tag_name() 或find_elements(By.TAG_NAME,value)定位
注意: find_elements_by_tag_name()属于selenium3 定位方法,find_elements(By.TAG_NAME, value)属于selenium4 定位方法
from selenium import webdriver
import time
from selenium.webdriver.common.by import By
# 打开Chrome浏览器
driver= webdriver.Chrome()
# 请求 aol 邮箱注册
driver.get('https://www。baidu.com/')
# 使用 find_elements(By.TAG_NAME, value) 方法定位
tag = driver.find_elements(By.TAG_NAME,"input")
# 遍历 tag
for baidu in tag:
if baidu.get_attribute('autocomplete') =="off":
baidu.send_keys("Python Web自动化测试")
# 点击百度一下 (使用的ID定位)
driver.find_element(By.ID,'su').click()
time.sleep(5)
# driver.close()关闭驱动,driver.quit()退出驱动,开发中一般建议使用driver.quit()
driver.quit()
注意:页面出现多个 input 标签时,可以通过 for 遍历每个对象,然后通过 autocomplete 属性值等于 off 的元素判断定位。项目中参考列子举一反三。
三、JavaScript 与 JQuery 定位方法实战
项目开发中不推荐使用 JavaScript 与 JQuery 定位方法。迫不得已可以选择这样的定位方法,确保项目能正常开发。
3.1 JavaScript 常用定位方法
3.1.1 getElementById 定位
from selenium import webdriver
import time
from selenium.webdriver.common.by import By
# 打开Chrome浏览器
driver= webdriver.Chrome()
# 请求简书
driver.get('https://www.jianshu.com/sign_in')
# 等待时间,让浏览器加载一下
time.sleep(3)
# 使用 getElementById 定位; 单点注册
driver.execute_script("document.getElementById('js-sign-up-btn').click();")
time.sleep(3)
# driver.close()关闭驱动,driver.quit()退出驱动,开发中一般建议使用driver.quit()
driver.quit()
3.1.1 getElementByClassName 定位
from selenium import webdriver
import time
from selenium.webdriver.common.by import By
# 打开Chrome浏览器
driver= webdriver.Chrome()
# 请求简书
driver.get('https://www.jianshu.com/sign_in')
# 使用 getElementByClassName + 索引 定位;单点登录
driver.execute_script('document.getElementByClassName("active")[0].click();')
time.sleep(3)
# driver.close()关闭驱动,driver.quit()退出驱动,开发中一般建议使用driver.quit()
driver.quit()
3.1.1 getElementByTagName 定位
from selenium import webdriver
import time
from selenium.webdriver.common.by import By
# 打开Chrome浏览器
driver= webdriver.Chrome()
# 请求简书
driver.get('https://www.jianshu.com/sign_in')
# 使用 getElementByTagName + tag名称 + 索引 + 属性值
driver.execute_script('document.getElementByTagName("input")[2].value="username";')
driver.execute_script('document.getElementByTagName("input")[2].value="password";')
time.sleep(3)
# driver.close()关闭驱动,driver.quit()退出驱动,开发中一般建议使用driver.quit()
driver.quit()
3.2 JQuery 常用定位方法
3.2.1 querySelectorAll() 定位
from selenium import webdriver
import time
from selenium.webdriver.common.by import By
# 打开Chrome浏览器
driver= webdriver.Chrome()
# 请求简书
driver.get('https://www.jianshu.com/sign_in')
# 等待时间,让浏览器加载一下
time.sleep(3)
# 输入登录名与密码
driver.find_element(By.ID,'session_email_or_mobile_number').send_keys('13142077700')
driver.find_element(By.ID,'session_password').send_keys('12345678')
# 使用css 选择器定位登录按钮
driver.execute_script('document.querySelectorAll(".sign-in-button")[0].click();')
time.sleep(3)
# driver.close()关闭驱动,driver.quit()退出驱动,开发中一般建议使用driver.quit()
driver.quit()
总结:Selenium4 定位划重点
- 页面中使用 find_element() 元素定位。优先级: ID 定位、NAME 定位、XPATH定位 、CSS 定位等。
- 页面中使用 find_elements() 元素定位。优先级: CSS 定位、TAG_NAME 定位等。
- 页面中使用 execute_scrip() 元素定位。优先级: getElementById 定位、getElementByClassName 定位、getElementByTagName 定位、querySelectorAll 定位等。