Selenium之WebDriverAPI

获取标签元素

8种获取标签元素的定位方式,一般使用css selector定位,如果定位不到则使用xpath定位

# 通过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种的底层封装。参数化的一种调用方式而已。

浏览器操作

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

浏览器窗口操作

 1 # 获取当前浏览器的大小
 2 driver.get_window_size()
 3  
 4 # 通过像素设置浏览器的大小
 5 driver.set_window_size(width,height)
 6  
 7 # 获取当前窗口针对于Windows的位置的坐标x,y
 8 driver.get_window_position()
 9  
10 # 设置当前窗口针对Windows的位置,x,y
11 driver.set_window_position(20,20)
12  
13 # 最大化当前窗口,不需要传参
14 driver.maximize_window()
15  
16 # 返回当前操作的浏览器句柄
17 driver.current_window_handle
18  
19 # 返回所有打开server的浏览器句柄
20 driver.window_handles
21 
22 handles = driver.window_handles[-1]   #定位到最后打开的页面
23 driver.switch_to.window(handles)   #切换到最后打开的页面
24 
25 driver.window_handles[0]  #定位到第一个打开的页面

截取当前页面

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

执行JavaScript语句

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

其他

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

ElementApi接口

 1 # 根据标签属性名称,获取属性value
 2 element.get_attribute(style)
 3  
 4 # 向输入框输入字符串 如果input的type为file类型 可以输入文件绝对路径上传文件
 5 element.send_keys()
 6  
 7 # 清除文本内容
 8 element.clear()
 9  
10 # 鼠标左键点击操作
11 element.click()
12  
13 # 通过属性名称获取属性
14 element.get_property(id)
15  
16 # 返回元素是否可见 True or False
17 element.is_displayed()
18  
19 # 返回元素是否被选中 True or False
20 element.is_selected()
21  
22 # 返回标签元素的名字
23 element.tag_name
24  
25 # 获取当前标签的宽和高
26 element.size
27  
28 # 获取元素的文本内容
29 element.text
30  
31 # 模仿回车按钮 提交数据
32 element.submit()
33  
34 # 获取当前元素的坐标
35 element.location
36  
37 # 截取图片
38 element.screenshot()

Cookie操作

# 根据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)

常见异常

NoSuchElementException:没有找到元素
 
NoSuchFrameException:没有找到iframe
 
NoSuchWindowException:没找到窗口句柄handle
 
NoSuchAttributeException:属性错误
 
NoAlertPresentException:没找到alert弹出框
 
ElmentNotVisibleException:元素不可见
 
ElementNotSelectableException:元素没有被选中
 
TimeoutException:查找元素超时

 

Selenium之WebDriverAPI

上一篇:Android--aapt命令


下一篇:Github 获取仓库的releases API