selenium中的基础用法大全
标红为最常用
1、输入框(input):
driver.find_element_by_id("3").get_attribute('value')
2、页面文本
driver.find_element_by_xpath("//*[@id='3']").text
3、页面标题
driver.title
4.获取输入框内容:
#当我们使用send_keys输入的内容不存在页面标签中时,可以通过get_property()获取当前文本框显示的内容
driver.find_element_by_id("kw").get_property()
Selenium Python 总结一些工作中可能会经常使用到的API。
1.获取当前页面的Url
方法:current_url
实例:driver.current_url
2.获取元素坐标
方法:location
解释:首先查找到你要获取元素的,然后调用location方法
实例:driver.find_element_by_xpath("xpath").location
3.表单的提交
方法:submit
解释:查找到表单(form)直接调用submit即可
实例:driver.find_element_by_id("form1").submit()
4.获取CSS的属性值
方法:value_of_css_property(css_name)
实例:driver.find_element_by_css_selector("input.btn").value_of_css_property("input.btn")
5.获取元素的属性值
方法:get_attribute(element_name)
实例:driver.find_element_by_id("kw").get_attribute("kw")
6.判断元素是否被选中
方法:is_selected()
实例:driver.find_element_by_id("form1").is_selected()
7.返回元素的大小
方法:size
实例:driver.find_element_by_id("iptPassword").size
返回值:{'width': 250, 'height': 30}
8.判断元素是否显示
方法:is_displayed()
实例:driver.find_element_by_id("iptPassword").is_displayed()
9.判断元素是否被使用
方法:is_enabled()
实例:driver.find_element_by_id("iptPassword").is_enabled()
10.获取元素的文本值
方法:text
实例:driver.find_element_by_id("iptUsername").text
11.元素赋值
方法:send_keys(*values)
实例:driver.find_element_by_id("iptUsername").send_keys('admin')
12.返回元素的tagName
方法:tag_name
实例:driver.find_element_by_id("iptUsername").tag_name
返回值:定位的元素的标签名 如p div标签
13.删除浏览器所有的cookies
方法:delete_all_cookies()
实例:driver.delete_all_cookies()
14.删除指定的cookie
方法:delete_cookie(name)
实例:deriver.delete_cookie("my_cookie_name")
15.关闭当前浏览器页面
方法:close() 指当前页面
实例:driver.close()
16.关闭浏览器并且退出驱动程序(unittest中执行完都需要调个quit函数避免驱动程序多次调用导致系统os报错)
方法:quit()
实例:driver.quit()
17.返回上一页
方法:back()
实例:driver.back()
18.清空输入框
方法:clear()
实例:driver.clear()
19.浏览器窗口最大化
方法:maximize_window()
实例:driver.maximize_window()
20.查看浏览器的名字
方法:name
实例:drvier.name
21.返回当前会话中的cookies
方法:get_cookies()
实例:driver.get_cookies()
22.根据cookie name 查找映射Value值
方法:driver.get_cookie(cookie_name)
实例:driver.get_cookie("NET_SessionId")
23.截取当前页面
方法:get_screenshot_as_file(filename)
实例:driver.get_screenshot_as_file("F:\\Python\\aa.bmp")
24.获取当前窗口的坐标
方法:get_window_position()
实例:driver.get_window_position()
25.获取当前窗口的长和宽
方法:get_window_size()
实例:driver.get_window_size()
ActionChains类鼠标操作的常用方法:
引入ActionChains类:from selenium.webdriver.common.action_chains import ActionChains
26.右击
方法:context_click()
实例:ActionChains(driver).context_click(driver.find_element_by_id("id")).perform()
27.双击
方法:double_click()
实例:ActionChains(driver).double_click(driver.find_element_by_name("name")).perform()
28:鼠标拖放
方法:drag_and_drop(source, target)
source:鼠标按下的源元素;target:鼠标释放的目标元素
实例:element = driver.find_element_by_name("name")
target = driver.find_element_by_name("name")
ActionChains(driver).drag_and_drop(element, target).perform()
29:鼠标悬停在一个元素上(hover)
方法:move_to_element()
实例:above = driver.find_element_by_xpath("xpath路径")
ActionChains(driver).move_to_element(above).perform()
30:按下鼠标左键在一个元素上
方法:click_and_hold()
实例:left = driver.find_element_by_name("name")
ActionChains(driver).click_and_hold(left).perform()
键盘事件:
引入Keys类包:from selenium.webdriver.common.keys import Keys
31:输入
方法:send_keys()
实例:driver.find_element_by_id("id").send_keys("XXX")
32:输入空格
方法:send_keys(Keys.SPACE)
实例:driver.find_element_by_id("id").send_keys(Keys.SPACE)
33:ctrl + a 全选输入框的内容
ctrl + x 剪切输入框的内容
ctrl + v 粘贴到输入框
ctrl + c 复制
方法:send_keys(Keys.CONTROL,'a')
实例:driver.find_element_by_id("id").send_keys(Keys.CONTROL,'a')
34:回车代替点击
方法:send_keys(Keys.ENTER)
实例:driver.find_element_by_id("id").send_keys(Keys.ENTER)
35:制表键(Tab)
方法:send_keys(Keys.TAB)
实例:driver.find_element_by_id("id").send_keys(Keys.TAB)
36:回退键(Esc)
方法:send_keys(Keys.ESCAPE)
实例:driver.find_element_by_id("id").send_keys(Keys.ESCAPE)
等待时间
导入 WebDriverWait 包
from selenium.webdriver.support.ui import WebDriverWait
导入 time 包
import time
37:固定等待时间
方法:sleep()
实例:time.sleep(5) # 等待5秒
38:等待一个元素被发现,或一个命令完成,超出了设置时间则抛出异常智能等待。
方法:implicitly_wait()
实例:driver.implicitly_wait(30)
39:在设置时间内,默认每隔一段时间检测一次当前页面元素是否存在,如果超过设置时间检测不到则抛出异常
"方法:WebDriverWait()"
#WebDriverWait(driver, timeout, poll_frequency=0.5, ignored_exceptions=None)
#——driver:WebDriver的驱动程序(Ie, Firefox, Chrome或远程)
#——timeout:最长超时时间,默认以秒为单位
#——poll_frequency:休眠时间的间隔(步长)时间,默认为0.5秒
#——ignored_exceptions:超时后的异常信息,默认情况下抛NoSuchElementException异常
实例:
element = WebDriverWait(driver, 10).until(lambda x: x.find_element_by_id("id"))
#一般由unit()或until_not()方法配合使用,同上:
调用该方法提供的驱动程序作为一个参数,直到返回值不为False。
——until(method, message=’’)
调用该方法提供的驱动程序作为一个参数,直到返回值为False。
——until_not(method, message=’’)
# 还可以与expected_conditions 一起使用
from selenium.webdriver.support import expected_conditions as EC
# 实例: 判断某个元素是否可见并且是enable的,这样才clickable
WebDriverWait(dr,15,1).until(EC.element_to_be_clickable((By.ID,"EmployeeListMenu")),"Not Find element")
40:选择当前页面上所有tag
name为input的元素
inputs = driver.find_elements_by_tag_name(‘input‘)
41:从中过滤出type为checkbox的元素,并勾选上
for input in inputs:
if input.get_attribute(‘type‘) == ‘checkbox‘:
input.click()
42:使用CSS定位选择所有type为checkbox的元素,并勾选上
checkboxes = driver.find_elements_by_css_selector(‘input[type = checkbox]‘)
for checkbox in checkboxes:
checkbox.click()
43:把最后一个checkbox的勾去掉,pop()方法空参数时,默认移除list中的最后一个元素。
driver.find_elements_by_css_selector(‘input[type = checkbox]‘).pop().click()
44:切换浏览器窗口(handle)
# 切换不同的tab页
方法:driver.switch_to.window(window_name)
# 备注:从A页跳转到B页,句柄已经切换过去,但是焦点没有切过去,所以需要switch_to.window,把焦点也切过去,才可以在当前页进行操作。
# 切换是思路,获取所有的句柄,因为返回是一个list,而且要切换的对象都是最后一个,可以使用[-1]直接切过去
# 例如:
driver.switch_to.window(driver.window_handles[-1])
45:返回上一级表单
方法: driver.switch_to_parent_content()#旧方法
driver.switch_to.parent_content#新方法
46:返回最外层表单
方法: driver.switch_to_default_content()#旧方法
driver.switch_to.default_content()#新方法
47:切换到指定frame中
方法:driver.switch_to.frame('xxx')
实例:driver.switch_to.frame('frame_name')
driver.switch_to.frame(index)
driver.switch_to.frame(driver.find_elements_by_tag_name("iframe")[0])
48:获取当前page的title
方法:driver.title
实例:driver.title
49:焦点切换到弹窗。
方法:driver.switch_to_alert()
实例:driver.switch_to_alert()
50:前进
方法:
driver.forward()
51:刷新页面
方法:driver.refresh()
52:下拉框选择(select标签下)
"""定位下拉框"""
#定位要进行下拉框的元素
select = driver.find_element_by_css_selector('#nr')
# 通过索引定位
Select(select).select_by_index(2)
# 通过value属性
Select(select).select_by_value("50")
# 通过文本描述
Select(select).select_by_visible_text("每页显示50条")
53.警告框处理:
"""警告框处理"""
#获取警告框文本信息
AlertText = driver.switch_to.alert.text
print(AlertText)
#模拟点击确定操作
driver.switch_to.alert.accept()
#模拟点击取消操作
driver.switch_to.alert.dismiss()
54.去除只读属性(readonly)
"""去除只读属性"""
#实例12306,日期选择
# 移除readonly属性
js_readonly = 'document.getElementById("train_date").removeAttribute("readonly");'
driver.execute_script(js_readonly)
# 清空 开始日期
# driver.find_element_by_id("train_date").clear()
# 输入新的日期
# driver.find_element_by_id("train_date").send_keys("2020-05-01")
55.获取父节点下所有子节点的文本内容
elements = driver.find_elements_by_xpath("//ul[@id='treeDemo']") # 定位到列表的顶级元素栏
for element in elements:
list_return = element.text # 获取列表栏的文本信息
56.利用send_keys上传图片
#F:\dd.jpg 为本地图片路径
driver.find_element_by_id("file_select").send_keys("F:\dd.jpg")
56.复选框操作
Len()方法可以用来计算元素的个数
click()方法是对某个元素进行勾选;
pop().click(),其实是对某个元素取消勾选
如果只想勾选一组元素中的某一个该如何操作呢?
pop()或pop(-1): 默认获取一组元素中的最后一个。
pop(0): 默认获取一组元素中的第一个。
pop(1): 默认获取一组元素中的第二个。
这样就可以操作这一组元素中的任意一个元素了,只需数一数需操作的元素是这一组中的第几个。
57.滚动条操作
浏览器滚动条并没有提供相应的操作方法。在这种情况下,就可以借助JavaScript来控制浏览器的滚动条。 WebDriver提供了execute_script()方法来执行JavaScript代码。
js="window.scrollTo(0,2500);" #0为起始,2500为终点
driver.execute_script(js)
js = 'window.scrollTo(0,document.body.scrollHeight)'#滚动到浏览器底部
driver.execute_script(js)
time.sleep(2)
js = 'window.scrollTo(0,document.body.scrollTop=0)'#滚动到浏览器顶部
driver.execute_script(js)
元素聚焦
1.虽然用上面的方法可以解决拖动滚动条的位置问题,但是有时候无法确定我需要操作的元素
在什么位置,有可能每次打开的页面不一样,元素所在的位置也不一样,怎么办呢?
2.这个时候我们可以先让页面直接跳到元素出现的位置,然后就可以操作了。同样需要借助JS去实现。
3.元素聚焦:
target = driver.find_element_by_xxxx()
driver.execute_script("arguments[0].scrollIntoView();", target)
58.HTML5视频播放
from selenium import webdriver
from time import *
driver=webdriver.Chrome()
driver.get("http://videojs.com/")
video=driver.find_element_by_xpath(".//*[@id='preview-player_html5_api']")
#返回文件的播放地址
url=driver.execute_script("return arguments[0].currentSrc;",video)
print(url)
print("start")
driver.execute_script("return arguments[0].play();",video)
#播放15秒
sleep(15)
print("stop")
driver.execute_script("arguments[0].pause();",video)
sleep(5)
driver.quit()
JavaScript函数有个内置的对象叫做arguements。arguements对象包含了函数调用的参数数组,[0]表示取对象的第1个值。
currentSrc熟悉返回当前音频/视频的URL。如果未设置音频/视频,则返回空字符串。
load()、play()、 pauseO等控制着视频的加载、播放和暂停。
59.捕获异常
Selenium中的常见异常
60.select框中如何得到当前选择的文本
# 返回所有选中的文本,以列表的形式展示
Select(select).all_selected_options[0].text
61.select框的用法大全
62.selenium无界面自动化测试
from selenium.webdriver.chrome.options import Options
opt = Options()
opt.add_argument('--no-sandbox') # 解决DevToolsActivePort文件不存在的报错
# opt.add_argument('window-size=1920x3000') # 设置浏览器分辨率
opt.add_argument('--disable-gpu') # 谷歌文档提到需要加上这个属性来规避bug
opt.add_argument('--hide-scrollbars') # 隐藏滚动条,应对一些特殊页面
opt.add_argument('blink-settings=imagesEnabled=false') # 不加载图片,提升运行速度
opt.add_argument('--headless') # 浏览器不提供可视化界面。Linux下如果系统不支持可视化不加这条会启动失败
# opt.binary_location = r"C:\Program Files (x86)\Google\Chrome\Application\chrome.exe" # 手动指定使用的浏览器位置
driver = webdriver.Chrome(options=opt)
- js修改页面样式
'''
调用js点击定位到自定义列显示图标,q元素ClassName为mmg-btnBackboardDn,然后修改style属性;
getElementsByClassName获取的数组,所有在后面加一个[0],取第一个值。
'''
js = "var q=document.getElementsByClassName(\"mmg-btnBackboardDn\")[0];q.style.display = \"block\";"
# 执行js
driver.execute_script(js)