其实我超喜欢pytest的fixtures
fixtures
windows下文件描述
①filename = 'E:\testresult.html’
②filename = r'E:\testresult.html'
③filename = 'E:/testresult.html'
python “UnicodeEncodeError: 'gbk' codec can't encode character问题解决。
with open(filepath, 'a+',encoding='utf-8') as fp #因为utf-8编码是可变长编码,可以识别任何的字符,所以就不会出现以上错误了。
返回元素的大小实例:driver.find_element_by_id("iptPassword").size
返回值:{'width': 250, 'height': 30}
获取当前窗口的坐标方法:get_window_position()
实例:driver.get_window_position()
获取当前窗口的长和宽方法:get_window_size()
实例:driver.get_window_size()
from selenium.webdriver.common.action_chains import ActionChains
右击方法:context_click()
实例:ActionChains(driver).context_click(driver.find_element_by_id("id")).perform()
双击方法:double_click()
实例:ActionChains(driver).double_click(driver.find_element_by_name("name")).perform()
鼠标拖放方法: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()
鼠标悬停在一个元素上(hover)方法:move_to_element()
实例:above = driver.find_element_by_xpath("xpath路径")
ActionChains(driver).move_to_element(above).perform()
按下鼠标左键在一个元素上方法:click_and_hold()
实例:left = driver.find_element_by_name("name")
ActionChains(driver).click_and_hold(left).perform()
from selenium.webdriver.common.keys import Keys
全选方法:send_keys(Keys.CONTROL,'a')
实例:driver.find_element_by_id("id").send_keys(Keys.CONTROL,'a')
回车代替点击方法:send_keys(Keys.ENTER)
实例:driver.find_element_by_id("id").send_keys(Keys.ENTER)
回退方法: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
方法:implicitly_wait()
实例:driver.implicitly_wait(30)
从中过滤出type为checkbox的元素,并勾选上
for input in inputs:
if input.get_attribute(‘type‘) == ‘checkbox‘:
input.click()
使用CSS定位选择所有type为checkbox的元素,并勾选上
checkboxes = driver.find_elements_by_css_selector(‘input[type = checkbox]‘)
for checkbox in checkboxes:
checkbox.click()
把最后一个checkbox的勾去掉
driver.find_elements_by_css_selector(‘input[type = checkbox]‘).pop().click()
切换浏览器handle
切换不同的tab页
方法:driver.switch_to.window(window_name)
- 备注:从A页跳转到B页,句柄已经切换过去,但是焦点没有切过去,所以需要switch_to.window,把焦点也切过去,才可以在当前页进行操作。
- 切换是思路,获取所有的句柄,因为返回是一个list,而且要切换的对象都是最后一个,可以使用[-1]直接切过去
例如:
driver.switch_to.window(driver.window_handles[-1])
返回上一级表单
方法: driver.switch_to_parent_content()#旧方法
driver.switch_to.parent_content#新方法
返回最外层表单
方法: driver.switch_to_default_content()#旧方法
driver.switch_to.default_content()#新方法
切换到指定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])
获取当前page的title,driver.name是浏览器的名字
方法:driver.title
实例:driver.title
获取当前窗口的长和宽
方法:get_window_size()
实例:driver.get_window_size()
获取当前页面的Url
方法:current_url
实例:driver.current_url
获取元素坐标
方法:location
解释:首先查找到你要获取元素的,然后调用location方法
实例:driver.find_element_by_xpath("xpath").location
获取当前窗口的坐标
方法:get_window_position()
实例:driver.get_window_position()
表单的提交
方法:submit
解释:查找到表单(from)直接调用submit即可
实例:driver.find_element_by_id("form1").submit()
设定页面加载限制时间
driver.set_page_load_timeout(30)
driver.execute_script('window.stop()') #当页面加载时间超过设定时间,通过执行Javascript来stop加载,即可执行后续动作
获取CSS的属性值
方法:value_of_css_property(css_name)
实例:driver.find_element_by_css_selector("input.btn").value_of_css_property("input.btn")
获取元素的属性值
方法:get_attribute(element_name)
实例:driver.find_element_by_id("kw").get_attribute("kw")
判断元素是否被选中
方法:is_selected()
实例:driver.find_element_by_id("form1").is_selected()
判断元素是否显示
方法:is_displayed()
实例:driver.find_element_by_id("iptPassword").is_displayed()
判断元素是否被使用
方法:is_enabled()
实例:driver.find_element_by_id("iptPassword").is_enabled()
别人那里看到的
def highlight(func):
def apply_style(element):
js = "arguments[0].style.border='6px solid red'"
driver.execute_script(js, element)
@wraps(func)
def wrapper(self, *args, **kwargs):
element = func(self, *args, **kwargs)
apply_style(element)
return element
return wrapper
def screenshot(func):
def screen_shot(screen_name):
driver.save_screenshot(screen_name)
@wraps(func)
def wrapper(self, *args, **kwargs):
element = func(self, *args, **kwargs)
screen_shot(str(args[-1]) + '.jpg') # 默认是以定位元素属性为文件名
return element
return wrapper
class Action(object):
def __init__(self, driver):
self.driver = driver
@screenshot
@highlight
def find_element(self, *loc):
try:
WebDriverWait(self.driver, 15).until(lambda driver: driver.find_element(*loc).is_displayed())
return self.driver.find_element(*loc)
except Exception as e:
return e
def highlight(element, element_name=None, debug=True):
'''
debug 参数用来开关截图功能
'''
# 高亮元素
def apply_style():
driver.execute_script("arguments[0].style.border='6px solid red'", element)
# 截图
def screen_shot(screen_name):
driver.save_screenshot(screen_name)
if debug:
try:
screen_shot(str(element_name) + '_before.jpg')
apply_style()
screen_shot(str(element_name) + '_after.jpg')
except Exception as e:
return e
apply_style()
element = driver.find_element(By.ID, 'kw')
highlight(element, 'kw')
driver = webdriver.Firefox()
driver.get('http://www.baidu.com')
action = Action(driver)
action.find_element(By.ID, 'su')
time.sleep(3)
网友评论