Python3+Selenium UI自动化

Selenium UI自动化

1、安装

1、安装python3

2、下载selenium:pip install selenium == 3.12.0

3、下载Chrome:66.0.3359.139或Firefox

4、Firefox安装插件:地址栏输入about:addons;分别搜索Firebug和FirePath,并下载

浏览器驱动下载:https://www.seleniumhq.org/download/

chromedriver.exe

复制到python 安装目录~\Python37

HTMLTestRunner.py

复制到~\Python37\Lib

注意:文件名不能用 selenium

新建的名称叫selenium.py,导致Python会先导入这个文件,然后再导入标准库里面的selenium.py。

把当前目录下的文件删除或者重命名之后再run正常。

代码:

```

# coding:utf-8

from selenium import webdriver import time

```

1、设置浏览器的驱动

driver = webdriver.Chrome()

2、去掉Chrome浏览器顶部的“正在受到自动测试软件控制”:

option = webdriver.ChromeOptions() option.addargument('disable-infobars') driver = webdriver.Chrome(chromeoptions=option)

3、打开网址

driver.get("https://www.baidu.com/")

2、UI自动化操作

1、打开浏览器

设置浏览器的驱动

driver = webdriver.Chrome()

1、Chrome浏览器静默模式:不弹出浏览器

option = webdriver.ChromeOptions()

option.addargument('headless') driver = webdriver.Chrome(chromeoptions=option)

2、去掉Chrome浏览器顶部的“正在受到自动测试软件控制”:

option = webdriver.ChromeOptions()

option.addargument('disable-infobars') driver = webdriver.Chrome(chromeoptions=option)

driver = webdriver.Firefox()

2、进入论坛

driver.get("http://    ")

3、登录

1、找到账号和密码输入框

定位输入框的位置

定位元素

1、用id定位:findelementby_id()

2、用classname定位:findelement_byclassname()

3、用链接文本定位:findelementbylinktext()

4、用部分链接文本定位:findelementby_partiallinktext()

5、用标签名定位:findelementbytagname()---从没用过

6、最常用:findelementby_xpath()

7、findelementbycssselector()

定位一组对象

与定位单个对象类似,只是要把element换成elements,如:findelementsbyclassname()【最常用】

2、点击元素:.click()

3、输入账号和密码

文本框输入

1、清空输入框默认文本:.clear()

2、.send_keys("自动化测试")

4、点击登录

登陆后有弹窗,为了确定正确登录,需要断言

1、普通弹出框获取元素属性

1、文本:.text

2、元素尺寸:.size

3、获取其他属性如class:.findelementbyid().getattribute("class")

4、元素是否可见:findelementbyid().isdisplayed()

若元素可见返回True,否则返回False

2、页面弹出alert

alert = driver.switch_to.alert

查看alert中的文字

print alert.text

点击确定

alert.accept()

点击取消(如果有)

alert.dismiss()

3、获取当前网页信息

1、当前网页url:driver.current_url

2、网页标题:driver.title

4、页面跳转

1、如果在当前窗口跳转,则无需其他操作

2、新开窗口则需要切换窗口:点击某个元素以后会新开标签页,这时候需要切换窗口

allhandles = driver.windowhandles

currwindow = driver.currentwindowhandle for k in allhandles: if k != currwindow: driver.switchto.window(k)

5、点击下拉页面

页面上下拉,要用js

1、下拉指定高度

js = 'document.documentElement.scrollTop=1000;'

driver.execute_script(js)

顶部:0

底部:把值写大一点

2、用目标元素做参考去拖动下拉条

targetelement = driver.findelementbyid()

js = 'arguments[0].scrollIntoView();' driver.executescript(js, targetelement)

3、js操作补充

1、去掉新开标签页:target="_blank"属性

js = 'document.getElementsByClassName("")[0].target="";'

driver.execute_script(js)

2、去掉只读readonly属性

js = 'document.getElementById("").removeAttribute("readonly")'

driver.execute_script(js)

6、鼠标移动到发帖后会弹出发帖选项

鼠标操作

导入鼠标操作库:from selenium.webdriver.common.action_chains import ActionChains

1、右键单击:context_click()

2、双击:double_click()

3、拖动:draganddrop()

4、鼠标悬停:movetoelement()

5、按下左键不松手:clickandhold()

键盘事件

导入键盘操作库:from selenium.webdriver.common.keys import Keys

1、删除backspace键:findelementby_id().sendkeys(Keys.BACKSPACE)

2、Ctrl+a:.send_keys(Keys.CONTROL, 'a')

3、回车:.send_keys(Keys.ENTER)

7、输入帖子信息

1、定位iframe

iframe = driver.findelementby_xpath()

切换到iframe

driver.switch_to.frame(iframe) ...

跳出iframe

driver.switchto.defaultcontent()

你可能感兴趣的:(Python3+Selenium UI自动化)