创建一个浏览器对象

from selenium import webdriver
browser = webdriver.Chrome()

WebDriver在将控制权返回给测试脚本之前,会一直等待到页面完全加载完毕,但如果页面使用了很多AJAX,WebDriver可能无法准确判断页面是否完全加载。

打开页面

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

不能省略http:// 或 https://

获取页面源码

html = browser.page_source

定位HTML元素

定位一个元素

含义

find_element_by_tag_name

通过标签定位

find_element_by_id

通过元素id定位

find_element_by_name

通过元素name定位

find_element_by_class_name

通过类名进行定位

find_element_by_css_selector

通过css选择器进行定位

find_element_by_xpath

通过xpath表达式定位(xpath和xml中的类似)

find_element_by_link_text

通过完整超链接文本定位(不是通过超链接的地址,而是超链接上面的文字描述)

find_element_by_partial_link_text

通过部分链接定位

如果没有发现任何元素,将会抛出NoSuchElementException异常。

以上的方法仅返回第一个满足条件的元素,如果要返回多个元素,需要使用find_elements_by_xx。

输入文本

element.send_keys("selenium")

你输入的字符将会被添加在已有文本之后。如果传入多个文本,将依次添加。

在输入框中输入的字符不会自动清空,你可以使用clear方法输入区域的内容。

element.Clear()

快捷键

from selenium.webdriver.common.keys import Keys
element.send_keys(Keys.BACKSPACE) # 删除键
element.send_keys(keys.ENTER) # 回车键
element.send_keys(Keys.SPACE) # 空格键
element.send_keys(Keys.CONTROL, 'a') # Ctrl+A
element.send_keys(Keys.CONTROL, 'c') # Ctrl+C

点击按钮

element.click()

定位下拉框(select)

方法一:先定位select,再定位option选项。

browser.find_element_by_id("sel").find_element_by_xpath("//option[@value='晴']").click()

方法二:直接xpath定位。

browser.find_element_by_xpath("//*[@id='sel']/option[3]").click()

方法三:select模块定位

from selenium.webdriver.support.select import Select
element = browser.find_element_by_id("sel")
Select(element).select_by_index(2).click() # index 从0开始
Select(element).select_by_value('晴')
Select(element).select_by_visible_text('雨')

用Select定位后会直接选中不需要click()方法选中,也没有click()方法。

Select中的其他方法如下:

deselect_all() # 取消所有选项
deselect_by_index() # 取消对应 index 选项
deselect_by_value() # 取消对应 value 选项
deselect_by_visible_text() # 取消对应文本选项

以上方法需要select支持多选(multiple="true")

单选框(radio)复选框(checkbox)

element = browser.find_element_by_id('yes')
element.click()

就是定位HTML元素,没啥花样。

判断是否选中

browser.find_element_by_id('yes').is_selected()

判断是否可见

有些元素设置了display:none,这时候如果直接操作这种隐藏的元素,会报错:element not visible。

element.is_displayed()

定位弹框

1、alert弹框

alertElement = browser.switch_to_alert()
print(alertElement.text) # 获取对话框文本值
alertElement.accept() # 点击确认按钮

在现在的版本中,browser.switch_to_alert()已经过时了,

改成:alertElement = browser.switch_to.alert

2、confirm弹框

confirm 和 alert 是一样的,只是多了个点击取消按钮的方法。

confirmElement = browser.switch_to.alert
print(confirmElement.text) # 获取对话框文本值
confirmElement.dismiss() # 点击取消按钮

3、prompt弹框

prompt 又多了个输入框,send_keys 方法即可。

执行JS

js = "$('#sp').toggle();"
browser.execute_script(js)

退出

browser.quit()

示例:

为了测试,我们新建一个htnl网页

<html>
<head>
<title>SeleniumTest</title>
<script src="Scripts/jquery-1.10.2.min.js" type="text/javascript"></script> <style type="text/css">
tr{
height: 40px}
</style>
</head>
<body>
<table style="margin: 200px auto;">
<tr>
<td><input type="text" /></td>
</tr>
<tr>
<td><input type="text" id="txt1" /></td>
</tr>
<tr>
<td><input type="text" id="txt2" name="txt2" /></td>
</tr>
<tr>
<td><input type="text" class="c1" /></td>
</tr>
<tr>
<td><input type="text" class="c2" /></td>
</tr>
<tr>
<td><input type="text" id="txt6" /></td>
</tr>
<tr>
<td><span id="sp" style="display:none">隐藏的标签</span></td>
</tr>
<tr>
<td>
<a href="javascript:;">aaa</a>
<a href="https://www.baidu.com" target="_blank">bbb</a>
<a href="https://baike.baidu.com/" target="_blank">ccc</a>
</td>
</tr>
<tr>
<td>
<select id="sel">
<option value="无"></option>
<option value="晴">晴</option>
<option value="阴">阴</option>
<option value="雨">雨</option>
<option value="多云">多云</option>
</select>
</td>
</tr>
<tr>
<td>
<input type="radio" id="yes" />是
<input type="radio" id="no" />否
</td>
</tr>
<tr>
<td>
<input type="checkbox" id="chk1" name="chk" />语文
<input type="checkbox" id="chk2" name="chk" />数学
<input type="checkbox" id="chk3" name="chk" />英语
</td>
</tr>
<tr>
<td>
<input type="button" id="btn1" value="警告消息框" onclick="alert('警告警告')" />
<input type="button" id="btn2" value="确认消息框" onclick="confirm('是否确认')" />
<input type="button" id="btn3" value="提示消息框" onclick="prompt('提示注意')" />
<input type="button" id="btn4" value="显示" onclick="$('#sp').toggle();" />
</td>
</tr>
</table>
</body>
</html>

Python代码:

from selenium import webdriver
from selenium.webdriver.support.select import Select
from selenium.webdriver.common.keys import Keys
import time browser = webdriver.Chrome() # 创建浏览器对象 browser.get("http://localhost:8001/") # 打开网址
time.sleep(2) # 定位html元素
txt1 = browser.find_element_by_tag_name('input')
txt1.send_keys('tag_name=input') # 输入文本 txt2 = browser.find_element_by_id('txt1')
txt2.send_keys('id=txt1') txt3 = browser.find_element_by_name('txt2')
txt3.send_keys('name=txt2') txt4 = browser.find_element_by_class_name('c1')
txt4.send_keys('class_name=c1') txt5 = browser.find_element_by_css_selector('.c2')
txt5.send_keys('css=.c2') txt6 = browser.find_element_by_xpath("//input[@id='txt6']")
txt6.send_keys("xpath=//input[@id='txt6']") a1 = browser.find_element_by_link_text('bbb')
# a1.click() txt1.clear() # 清空文本
time.sleep(2) # 快捷键
txt2.send_keys(Keys.CONTROL, 'a')
time.sleep(1)
txt2.send_keys(Keys.CONTROL, 'c')
time.sleep(1)
txt2.send_keys(Keys.BACKSPACE)
time.sleep(1)
txt2.send_keys(Keys.CONTROL, 'v')
time.sleep(2) # 定位下拉框
browser.find_element_by_id("sel")\
.find_element_by_xpath("//option[@value='晴']").click()
time.sleep(1)
browser.find_element_by_xpath("//*[@id='sel']/option[3]").click() # 用Select模块定位
element = browser.find_element_by_id("sel")
Select(element).select_by_index(2) # index 从0开始
time.sleep(1)
Select(element).select_by_value('晴')
time.sleep(1)
Select(element).select_by_visible_text('雨') # 单选框
element = browser.find_element_by_id('yes')
element.click()
print(element.is_selected()) # 复选框
browser.find_element_by_id('chk1').click() # 判断元素是否可见
print(browser.find_element_by_id('sp').is_displayed()) # alert弹框
browser.find_element_by_id('btn1').click()
alertElement = browser.switch_to.alert
print(alertElement.text) # 获取对话框文本值
alertElement.accept() # 点击确认按钮 # confirm弹框
browser.find_element_by_id('btn2').click()
confirmElement = browser.switch_to.alert
print(confirmElement.text) # 获取对话框文本值
confirmElement.dismiss() # 点击取消按钮 # 执行JS
js = "$('#sp').toggle();"
browser.execute_script(js) # 退出
browser.quit()

element.is_displayed()

Python:Selenium 2:使用的更多相关文章

  1. python+selenium 浏览器的问题

    以前用selenium调用firefox是不需要驱动的,最近安装了python3.52+最新的firefox 发现调不起来了 搜索以后发现Firefox 47+需要搞个firefox的驱动 gecko ...

  2. 一次完整的自动化登录测试-基于python+selenium进行cnblog的自动化登录测试

    Web登录测试是很常见的测试!手动测试大家再熟悉不过了,那如何进行自动化登录测试呢!本文作者就用python+selenium结合unittest单元测试框架来进行一次简单但比较完整的cnblog自动 ...

  3. Python + Selenium 实现登录Office 365

    最近捡起之前用的Python + Selenium实现工作中需要的登录Office 365功能.(吐槽:国内网络真是卡,登录Office 365实属不易.另外Selenium这样的网站都要墙,无法理解 ...

  4. python+selenium+Robot

    准备工作: 1.下载python2.7 http://python.org/getit/ 2.下载下载setuptools [python 的基础包工具] 可以帮助我们轻松的下载,构建,安装,升级,卸 ...

  5. python+selenium运行报错UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-1: ordinal not in range(128)

    使用python+selenium运行自动化脚本时,打印某一段文字出现UnicodeEncodeError: 'ascii' codec can't encode characters in posi ...

  6. Functional testing - python, selenium and django

    Functional testing  - python selenium django - Source Code : from selenium import webdriverfrom sele ...

  7. python selenium自动化(二)自动化注册流程

    需求:使用python selenium来自动测试一个网站注册的流程. 假设这个网站的注册流程分为三步,需要提供比较多的信息: 在这个流程里面,需要用户填入信息.在下拉菜单中选择.选择单选的radio ...

  8. 使用python selenium进行自动化functional test

    Why Automation Testing 现在似乎大家都一致认同一个项目应该有足够多的测试来保证功能的正常运作,而且这些此处的‘测试’特指自动化测试:并且大多数人会认为如果还有哪个项目依然采用人工 ...

  9. Python+Selenium WebDriver API:浏览器及元素的常用函数及变量整理总结

    由于网页自动化要操作浏览器以及浏览器页面元素,这里笔者就将浏览器及页面元素常用的函数及变量整理总结一下,以供读者在编写网页自动化测试时查阅. from selenium import webdrive ...

  10. Python Selenium设计模式-POM

    前言 本文就python selenium自动化测试实践中所需要的POM设计模式进行分享,以便大家在实践中对POM的特点.应用场景和核心思想有一定的理解和掌握. 为什么要用POM 基于python s ...

随机推荐

  1. 爬虫之图片懒加载技术及js加密

    图片懒加载 图片懒加载概念: 图片懒加载是一种网页优化技术.图片作为一种网络资源,在被请求时也与普通静态资源一样,将占用网络资源,而一次性将整个页面的所有图片加载完,将大大增加页面的首屏加载时间.为了 ...

  2. AI零基础入门之人工智能开启新时代—下篇

    人工智能概述 人工智能的定义 · 人工智能是通过机器来模拟人类认识能力的一种科技能力 · 人工智能最核心的能力就是根据给定的输入做出判断或预测 · 思考:通过什么途径才能让机器具备这样的能力? · 举 ...

  3. CSS特例定位方式

    同级向下一个元素定位,一个+表示下一个元素,++表格下下个元素 input[name='name1'] +input td:eq(0)表示第一个td元素,此定位方式限于执行js,在selenium时用 ...

  4. HTTP协议头部与Keep-Alive模式详解(转)

    转自:http://a280606790.iteye.com/blog/1095085 http1.1 中怎么打开持久连接,怎么关闭,怎么传输数据(确定本次数据是否传输完毕) 1.什么是Keep-Al ...

  5. CentOS7更换国内源

    前言 CentOS 有个很方便的软件安装工具yum,但是默认安装完CentOS,系统里使用的是国外的CentOS更新源,这就造成了我们使用默认更新源安装或者更新软件时速度很慢的问题,甚至更新失败. 为 ...

  6. 在centos 7云服务器上搭建Apache服务器并访问到你的网站

    网站是指在互联网上根据一定的规则,用HTML等语言制作的网页的集合.网站的目的是用来展示一些信息,如果是个人网站则是为了展示自己的一些想被人知道的东西,例如自己的一些作品,又或者是通过网站来达到盈利的 ...

  7. 使用mongo获取文章

    先在命令行中输入mongo,进入mongo,然后 show dbs # 从结果中发现有cmb_demo_23_hacker use cmb_demo_23_hacker db.all_in_one.f ...

  8. python获取多线程的返回值

    import threading class MyThread(threading.Thread): def __init__(self,func,args=()): super(MyThread,s ...

  9. Windows系统MySQL安装配置

    MySQL是一个开放源代码的数据库管理系统,是由MySQL AB公司开发.发布并支持的,现在属于Oracle旗下产品. 与其他大型数据库管理系统如Oracle.DB2.SQL Server等相比,虽然 ...

  10. ora-01033 oracle initialization or

    这次出现这个问题是源于错删了 DBF文件. 解决方案如下: 1.打开SQL Plus 最后把你删掉的那个文件的表空间删掉就好了