UI自动化(十)selenium定位

时间:2021-08-30 06:45:47

浏览器操作

 
1
2
3
4
5
6
7
8
# 刷新
driver.refresh()
 
# 前进
driver.forward()
 
# 后退
driver.back()

获取标签元素

 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
# 通过ID定位目标元素
driver.find_element_by_id('i1')
 
# 通过className定位目标元素
driver.find_element_by_class_name('c1')
 
# 通过name属性定位目标元素
driver.find_element_by_name('n1')
 
# 通过Xpath定位目标元素
driver.find_element_by_xpath('//*[@id="i1"]')
 
# 通过css Selector定位目标元素
driver.find_element_by_css_selector('#i1')
 
# 通过标签名称定位(注:在一个页面中,标签一定会重复,所以不用这个来进行定位)
driver.find_element_by_tag_name('input')
 
# 通过标签中的文本查找元素
driver.find_element_by_link_text('登录')
 
# 通过标签中文本的模糊匹配查找
driver.find_elements_by_partial_link_text('录')

获取标签元素常用的一共有8种定位方式,而Selenium实际提供了18种定位方式,还有8中是上面的复数形式,这里就不一一介绍了,实际运用中并不常用,还有2种实际上是这上面所说16种的底层封装。参数化的一种调用方式而已。

Cookie操作

 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
# 根据cookieKey,获取cookie信息
cookie = driver.get_cookie('cookieKey')
 
# 获取所有cookie信息
cookies = driver.get_cookies()
 
# 添加cookie,严格按照格式添加,cookie的key为name,value为value
driver.add_cookie({'name':'tmp','value':'123123123'})
 
# 删除所有cookie信息
driver.delete_all_cookies()
 
# 根据cookieKey删除对应cookie
driver.delete_cookie('UiCode')

窗口操作

 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
# 获取当前浏览器的大小
driver.get_window_size()
 
# 通过像素设置浏览器的大小
driver.set_window_size('width','height')
 
# 获取当前窗口针对于Windows的位置的坐标x,y
driver.get_window_position()
 
# 设置当前窗口针对Windows的位置,x,y
driver.set_window_position(20,20)
 
# 最大化当前窗口,不需要传参
driver.maximize_window()
 
# 返回当前操作的浏览器句柄
driver.current_window_handle
 
# 返回所有打开server的浏览器句柄
driver.window_handles

截取当前页面

 
1
2
3
4
5
# 获取当前页面的二进制图片数据,需要自己去写入文件
driver.get_screenshot_as_png()
 
# as_png的上层封装,只需要传入图片名称自动写成图片
driver.get_screenshot_as_file('fileName.png')

执行JavaScript语句

 
1
2
3
4
5
6
7
# 执行JavaScript语句
driver.execute_script('JavaScript Commond')
 
# 例:
# 通过js来操作滚动条
# 参数1:x  参数2: y
window.scrollTo(100,400);

关闭与退出

 
1
2
3
4
5
# 当开启多个时,关闭当前页面
driver.close()
 
# 退出并关闭所有页面驱动
driver.quit()

其他

 
1
2
3
4
5
6
7
8
9
10
11
# 返回页面源码
driver.page_source
 
# 返回tag标题
driver.title
 
# 返回当前Url
driver.current_url
 
# 获取浏览器名称 如:chrome
driver.name

 

 

常见异常

 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
NoSuchElementException:没有找到元素
 
NoSuchFrameException:没有找到iframe
 
NoSuchWindowException:没找到窗口句柄handle
 
NoSuchAttributeException:属性错误
 
NoAlertPresentException:没找到alert弹出框
 
ElmentNotVisibleException:元素不可见
 
ElementNotSelectableException:元素没有被选中
 
TimeoutException:查找元素超时
switch-iframe
driver.switch_to.frame('top-frame')# 切换第一次层iframe
driver.find_element_by_css_selector('#newtag').send_keys('111')
driver.switch_to.frame('baidu-frame')# 切换第二层 iframe
driver.find_element_by_css_selector('#kw').send_keys(111)
driver.switch_to.parent_frame() # 回到上一层
driver.find_element_by_css_selector('#newtag').clear()#清除文本框内容
driver.switch_to.default_content() #回到默认层
driver.find_element_by_css_selector('#i1').clear()
switch-alert
driver.switch_to.alert.accept() # 点击alert的确认按钮
driver.switch_to.alert.dismiss() # 点击取消
鼠标悬浮的连贯操作
1.from selenium.webdriver.common.action_chains import ActionChains
# div = driver.find_element_by_css_selector('#a')
# disInput = driver.find_element_by_css_selector('#dis1')
# ActionChains(driver).move_to_element(div).click(disInput)
2.# js = "document.getElementById('dis1').style.display='';"
# driver.execute_script(js)
拖拽
s1 = driver.find_element_by_css_selector('#dragger') t1 = driver.find_element_by_css_selector('#i1') from selenium.webdriver.common.action_chains import ActionChains ActionChains(driver).drag_and_drop(s1,t1).perform()
select
element = driver.find_element_by_xpath('//select[1]')
from selenium.webdriver.support.select import Select
# 根据value进行操作
Select(element).select_by_value('4')
Select(element).select_by_index(3)