Selenium获取标签
seleniu提供了18种定位方式:8种单数、8种复数、3种父类
# 1、id定位方式 driver.find_element_by_id('i1').send_keys('123123') # 2、class定位 driver.find_element_by_class_name('classname').send_keys('456') # # 3、name定位 driver.find_element_by_name('name').send_keys('789') # 4、link_text 定位 driver.find_element_by_link_text('新建标签页面').click() driver.execute_script('window.scrollTO(0,0)') #执行js 将当前页面移动到最上面 #5、包含文本的定位方式 driver.find_element_by_partial_link_text('新建标签').click() #6、标签名定位,最不常用 driver.find_element_by_tag_name('input').send_keys('123') # 7、xpath定位 driver.find_element_by_xpath('//*[@id="i1"]').send_keys('123') # 8、cssSelector定位 driver.find_element_by_css_selector('#i1').send_keys('123') driver.find_element_by_css_selector('[name="n1"]').send_keys('123') #八种复数定位方式 # 所有的复数形式默认返回的都是一个列表 列表的顺序是按照html从上到下 # 定位的元素下如果还有子元素,则可以通过元素再次进行定位 #1、id element = driver.find_elements_by_id('i1') element[0].send_keys('123') #2、classname elements = driver.find_elements_by_class_name('inner') print(len(elements)) inputele = elements[0].find_elements_by_tag_name('input') print(inputele) inputele[0].send_keys('2222') driver.find_elements_by_partial_link_text() driver.find_elements_by_css_selector() driver.find_elements_by_name() driver.find_elements_by_tag_name() driver.find_elements_by_xpath() driver.find_elements_by_link_text() #最后两种 driver.find_element() driver.find_elements()
窗口操作
# 获取当前页面的标题
driver.title
# 获取当前浏览器的大小 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 handles = driver.window_handles[-1] #定位到最后打开的页面 driver.switch_to.window(handles) #切换到最后打开的页面
截取当前页面
# 获取当前页面的二进制图片数据,需要自己去写入文件 driver.get_screenshot_as_png() # as_png的上层封装,只需要传入图片名称自动写成图片 driver.get_screenshot_as_file('fileName.png')
执行js语句
# 执行JavaScript语句 driver.execute_script('JavaScript Commond') # 通过js来操作滚动条 js ='window.scrollTo(0,0);' driver.execute_script(js)
浏览器操作
# 刷新 driver.refresh() # 前进 driver.forward() # 后退 driver.back()
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')
关闭、退出
# 当开启多个时,关闭当前页面 driver.close() # 退出并关闭所有页面驱动 driver.quit()
其他
# 返回页面源码 driver.page_source # 返回tag标题 driver.title # 返回当前Url driver.current_url # 获取浏览器名称 如:chrome driver.name
ElementApi接口
# 根据标签属性名称,获取属性value element.get_attribute('style') # 向输入框输入字符串 如果input的type为file类型 可以输入文件绝对路径上传文件 element.send_keys() # 清除文本内容 element.clear() # 鼠标左键点击操作 element.click() # 通过属性名称获取属性 element.get_property('id') # 返回元素是否可见 True or False element.is_displayed() # 返回元素是否被选中 True or False element.is_selected() # 返回标签元素的名字 element.tag_name # 获取当前标签的宽和高 element.size # 获取元素的文本内容 element.text # 模仿回车按钮 提交数据 element.submit() # 获取当前元素的坐标 element.location # 截取图片 element.screenshot()
常见异常
NoSuchElementException:没有找到元素
NoSuchFrameException:没有找到iframe
NoSuchWindowException:没找到窗口句柄handle
NoSuchAttributeException:属性错误
NoAlertPresentException:没找到alert弹出框
ElmentNotVisibleException:元素不可见
ElementNotSelectableException:元素没有被选中
TimeoutException:查找元素超时