您的位置:首页 > 其它

selenium用法大全

2020-09-01 11:22 162 查看

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)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: