xpath css选择器

 1.什么是xpath?

XPath即为XML路径语言,它是一种用来(标准通用标记语言的子集)在 HTML\XML 文档中查找信息的语言。

2.什么是XML?

XML 指可扩展标记语言(EXtensible Markup Language)

XML 是一种标记语言,很类似 HTML

XML 的设计宗旨是传输数据,而非显示数据

获取元素

表达式

nodename:获取此节点的所有子节点

/:从根节点选取

//:从匹配选择的当前节点选择文档中的节点,从而不考虑他们的位置

.:选取当前节点

..:选取当前节点的父节点

@:选取属性

/根节点 

//title 全局模糊定位title

//head/. 定位head元素

//haad/.. 定位head元素的父元素

 //meta[@conent] 

 //meta[@conent=""]

3.什么是css选择器?

CSS 中,选择器是一种模式,用于选择需要添加样式的元素。计算机能够通过css选择器定位到相应元素,我们在编写自动化测试脚本的时候很多时候是在不断地找到css选择器。

1. 什么是框架

框架(framework)是一个框子 -- 指其约束性,也是一个架子 -- 指其支撑性,是一个基本概念上的结构,用于去解决或者处理复杂的问题。

框架是整个或部分系统的可重用设计,表现为一组抽象构件及构件实例间交互的方法;另一种定义认为,框架是可被应用开发者定制的应用骨架。前者是从应用方面而后者是从目的方面给出的定义。

框架,其实就是某种应用的半成品,就是一组组件,供你选用完成你自己的系统。简单说就是使用别人搭好的舞台,你来做表演。

2. 为什么使用框架

1)自己从头实现太复杂

2)使用框架能够更专注于业务逻辑,加快开发速度

3)框架的使用能够处理更多细节问题

4)使用人数多,稳定性,扩展性好

3.selenium工作原理

原理:webdriver是按照server–client的经典设计模式设计的。

server端就是remote server,可以是任意的浏览器。当我们的脚本启动浏览器后,该浏览器就是remote server,它的职责就是等待client发送请求并做出相应;client端简单说来就是我们的测试代码,我们测试代码中的一些行为,比如打开浏览器,转跳到特定的url等操作是以http请求的方式发送给被测试浏览器,也就是remote server;remote server接受请求,并执行相应操作,并在response中返回执行状态、返回值等信息。

4. selenium环境搭建

1)python3.7

2)Firefox35(大于43)

3)selenium2框架

稳定版 2.48.0 (pip install selenium==2.48.0)

4)浏览器驱动

注意:Firefox35(大于43)版本不需要下载驱动器,大于这个版本的需要,Chrome需要下载驱动器,下边分别演示。

selenium对浏览器操作

1)库的导入

fromseleniumimportwebdriver

2)创建浏览器对象

driver = webdriver.xxx()

使用dir(driver)查看方法

# 必须为大写driver = webdriver.Firefox()driver = webdriver.Chrome()

3)浏览器尺寸相关操作

maximize_window()    最大化get_window_size()    获取浏览器尺寸,打印查看set_window_size()    设置浏览器尺寸,400*400

4)浏览器位置相关操作

get_window_position()    获取浏览器位置set_window_position(x,y)    设置浏览器位置

注意:显示器以左上角为(0,0),所有的位置操作都是相对于显示器左上角展开的位移操作,单位是像素。

5)浏览器的关闭操作

close()关闭当前标签/窗口quit()关闭所有标签/窗口

6)页面请求操作

driver.get(url)请求某个url对应的响应refresh()刷新页面操作back()回退到之前的页面forward()前进到之后的页面

6. selenium获取断言信息

1 什么是断言

断言是编程术语,表示为一些布尔表达式,程序员相信在程序中的某个特定点该表达式值为真,可以在任何时候启用和禁用断言验证,因此可以在测试时启用断言而在部署时禁用断言。

2 获取断言信息的操作

current_url    获取当前访问页面url

title      获取当前浏览器标题

page_source      获取网页源码

print(driver.current_url)print(driver.title)print(driver.page_source)

get_screenshot_as_png()    保存图片

data=driver.get_screenshot_as_png()withopen("a.png","wb")asf:f.write(data)

get_screenshot_as_file(file) 直接保存

driver.get_screenshot_as_file("b.png")

selenium八大元素定位

8. 元素的操作

对元素的相关操作,一般要先获取到元素,再调用相关方法

element = driver.find_element_by_xxx(value)

1)点击和输入

点击操作---------->element.click()

清空/输入操作:

element.clear()---------------------->清空输入框

element.send_keys(data)-------->输入数据

9. 弹出框操作

进入到弹出框中

driver.switch_to.alert

接收警告

accept()

解散警告

dismiss()

发送文本到警告框

send_keys(data)

用法:driver.switch_to.alert.accept()

你可能感兴趣的:(xpath css选择器)