主要是selenium+pytest+POM
一、selenium
初始框架:
# 导入模块 from selenium import webdriver from time import sleep # 实例化浏览器对象 driver = webdriver.Chrome() # 打开网页 driver.get('***.html') # 展示效果 sleep(3)# 关闭页面 driver.quit()
元素定位
# 使用id定位element = driver.find_element_by_id('xx')# 使用name定位element = driver.find_element_by_name('xx')# class_name根据元素class属性定位元素element = driver.find_element_by_class_name('xx')# tag_name:标签名element = driver.find_element_by_tag_name('xx')# 使用link_text定位访问超链接l = driver.find_element_by_link_text('xx')# 只需要超链接的部分文本信息 pl = driver.find_element_by_partial_link_text('xx')
除了id唯一外,其他都有重复的可能,所以其他要保证唯一性
元素信息
element.size, element.text, element.get_attribute('class'), element.is_displayed(),element.is_enabled(), element.is_selected()
元素操作方法
element.send_keys('xx')、element.click()
driver操作
driver.back() driver.forward() driver.refresh() driver.close() driver.quit() driver.title driver.current_url
定位一组元素
usernames = driver.find_elements_by_name('xxx') for username in usernames: username.send_keys('xxx') sleep(3)
XPath
# XPath # 路径:定位 # 利用元素属性:定位 # 属性与逻辑结合:定位 # 层级与属性结合:定位 # 方法名:find_element_by_xpath(xpath)# 绝对路径:从最外层元素到指定元素之间所有经过元素层级的路径,以/html开始 # 相对路径:匹配任意层级的元素,不限制元素的位置,以//开始# 利用元素属性策略 # 语法://标签名[@属性名='属性值'] # 语法: //*[@属性名='属性值' and @属性名='属性值']# 层级与属性结合 # //*[@id='p1']/input # 延伸://*[text()="xxx"] 文本内容是xxx的元素 # //*[contains(@attribute,'xxx')] 属性中含有x