selenium 难定位元素,时间插件,下拉框定位,string
1.元素定位
ID定位元素:
findElement(By.id(“”));
通过元素的名称定位元素:
findElement(By.name(“”));
通过元素的html中的位置定位元素:
findElement(By.xpath(“”));
通过元素的标签名称定位元素:
findElement(By.tagName(“”));
通过元素的链接名称定位元素:
findElement(By.linkText(“”));
通过元素的类名定位元素:
findElement(By.className(“”));
通过元素的css定位元素:
findElement(By.cssSelector(“”));
通过元素的部分链接名称定位元素:
findElement(By.partialLinkText(“”));
2.元素操作
driver.findElement(By.id(element)).click();
driver.findElement(By.id(element)).sendKeys(“123456”);
WebElement text1 = driver.findElement(By.name("password"));
text1.sendKeys("123456");
3,页面操作
打开网页:driver.get("https://www.baidu.com");
关闭网页:driver.close();
在输入框中输入内容:text.sendKeys(“”);
清空输入框中的内容:text.clear();
获取输入框中的内容:text.getText();
选择下拉框中的元素:
Select select = new Select(wd.findElement(By.id("select")));
切换到某个frame:
driver.switchTo().frame("");
从一个frame切换到另一个frame:
driver.switchTo().frame("");
切换到某个window:
driver.switchTo().window("windowName");
返回父iframe:(一般在跳转frame之前都写上这个语句)
driver.switchTo().defaultContent();
刷新页面:driver.navigate().refresh();
页面前进后退:
driver.navigate().forward();
driver.navigate().back();
3,输入框
element.sendKeys(“test”);//在输入框中输入内容:
element.clear(); //将输入框清空
element.getText(); //获取输入框的文本内容:
4.下拉选择框
Select select = new Select(driver.findElement(By.id("select")));
select.selectByVisibleText(“A”);
select.selectByValue(“1”);
select.deselectAll();
select.deselectByValue(“1”);
select.deselectByVisibleText(“A”);
select.getAllSelectedOptions();
select.getFirstSelectedOption();
5.单选框
WebElement radio=driver.findElement(By.id("BookMode"));
radio.click(); //选择某个单选项
radio.clear(); //清空某个单选项
radio.isSelected(); //判断某个单选项是否已经被选择
6.多选框
WebElement checkbox = driver.findElement(By.id("myCheckbox."));
checkbox.click();
checkbox.clear();
checkbox.isSelected();
checkbox.isEnabled();
6.弹出对话框
Alert alert = driver.switchTo().alert();
alert.accept(); //确定
alert.dismiss(); //取消
alert.getText(); //获取文本
7.表单
WebElement approve = driver.findElement(By.id("approve"));
approve.click();
approve.submit();//只适合于表单的提交
8.上传文件
上传文件的元素操作:
WebElement adFileUpload =driver.findElement(By.id("WAP-upload"));
String filePath = "C:\test\\uploadfile\\media_ads\\test.jpg";
adFileUpload.sendKeys(filePath);
9.window和iframe的切换
driver.switchTo().defaultContent(); //返回到最顶层的frame/iframe
driver.switchTo().frame("leftFrame"); //切换到某个frame:
driver.switchTo().window("windowName"); //切换到某个window
10.调用js
Web driver对Java Script的调用是通过JavascriptExecutor来实现的,例如:
JavascriptExecutor js = (JavascriptExecutor) driver;
js.executeScript("JS脚本");
11.超时设置
WebDriver driver = new FirefoxDriver();
driver.manage().timeouts().implicitlyWait(10, TimeUnit.SECONDS); //识别元素时的超时时间
driver.manage().timeouts().pageLoadTimeout(10, TimeUnit.SECONDS); //页面加载时的超时时间
driver.manage().timeouts().setScriptTimeout(10, TimeUnit.SECONDS); //异步脚本的超时时间
关于frame:
- 如果网页存在iframe的话,传统的定位有时候找不到元素,需要切换frame;

# 切换到leftFrame定位“测井设计”
driver.switch_to_frame("leftFrame")
driver.find_element_by_link_text(u"设计").click()
# 切换到rightFrame定位“设计”(先回到主内容再次定位,否则二次定位认为嵌套)
driver.switch_to_default_content()
driver.switch_to_frame("rightFrame")
driver.find_element_by_id("start").click()

2.有些插件用的也是frame,如时间插件

# 先定位到时间选择框,点击
driver.find_element_by_id("logmin").click()
#通过xpath定位frame
frames = driver.find_element_by_xpath("/html/body/div[2]/iframe")
#切换到frame
driver.switch_to_frame(frames)
# 选择2017-1-5,通过xpath定位,点击
driver.find_element_by_xpath(
"/html/body/div/div[3]/table/tbody/tr[2]/td[5]").click()
# 最后切换回原来和右边的frame
driver.switch_to_default_content()
driver.switch_to_frame("rightFrame")

关于下拉框
- 一般的下拉框可以通过二次定位来实现;
#定位列表的一组数据
names = driver.find_element_by_xpath("//*[@id='DataTables_Table_0']/tbody").find_elements_by_tag_name("input")
2.如果下拉框的标签是option,可以用select;
#选择select定位
Select(driver.find_element_by_name("isImportant2")
).select_by_visible_text(u"是")
3.如果下拉框不是上面这种形式,而是调用其他地方生成的list,定位的时候,我目前没有非常好的法子。取了一个折中法子,使用键盘"上下键+enter"选择;
#选择xpath定位到下拉列表,选择向下,点击回车,进行选择
well = driver.find_element_by_xpath(
"/html/body/span/span/span[2]/ul/li[1]")
well.send_keys(Keys.DOWN)
well.send_keys(Keys.ENTER)
关于定位一列数据中的某一个;
- 定义了一个函数findname.py,获得含有关键字的列表名称,并返回list最大值;

def fnn(names, keys):
k = []
for name in names:
#循环获得属性为value的值
s = name.get_attribute("value")
#找到包含关键字keys的字符串
if keys in s:
k.append(s)
newest = max(k)
return newest


#先定位到列表,在定位input,返回list
names = driver.find_element_by_xpath(
"//*[@id='DataTables_Table_0']/tbody").find_elements_by_tag_name("input")
#关键字keys为zs
name = findname.fnn(names, "zs")
driver.find_element_by_link_text(name).click()

字符串包含判断:关键字 in string;

def fnn(names, keys):
k = []
for name in names:
#循环获得属性为value的值
s = name.get_attribute("value")
#找到包含关键字keys的字符串
if keys in s:
k.append(s)
newest = max(k)
return newest
selenium 难定位元素,时间插件,下拉框定位,string的更多相关文章
- selenium自动化实例: 多层框架中关于iframe的定位,以及select下拉框选择
对于一个自动化的初学者来说会很常见的遇到元素明明存在却始终定位不到, 从而导致脚本报错,当然定位不到元素的原因很多, 其中一种就是多层框架iframe导致的 下方截图示意: 下方为写脚本时候的示例并其 ...
- Python+selenium之获取文本值和下拉框选择数据
Python+selenium之获取文本值和下拉框选择数据 一.结合实例进行描述 1. 实例如下所示: #新增标签操作 def func_labels(self): self.driver.find_ ...
- selenium 难定位元素,时间插件,下拉框定位,string包含,定位列表中的一个,技巧
关于frame: 如果网页存在iframe的话,传统的定位有时候找不到元素,需要切换frame: # 切换到leftFrame定位“测井设计” driver.switch_to_frame(" ...
- selenium自学笔记---下拉框定位元素select
下拉框1.先定位select 然后在定位option city = driver.find_element_by_id("selCities_0") city.find_eleme ...
- Selenium实战总结(webwiew下拉框定位)
基于常见的两种下拉框的展示形式: 1.点击弹出下拉框: 2.鼠标移动弹出下拉框(move_to_element) 实例一[鼠标点击弹出的下拉框]: e.g百度首页的设置--高级搜索--时间: 导包: ...
- python selenium下拉框定位
一.前言 总结一下python+selenium select下拉选择框定位处理的两种方式,以备后续使用时查询: 二.直接定位(XPath) 使用Firebug找到需要定位到的元素,直接右键复制XPa ...
- selenium python (十二)下拉框的处理
#!/usr/bin/python# -*- coding: utf-8 -*-__author__ = 'zuoanvip' #下拉框在web页面上非常常见,对于下拉框的处理采用二次定位的方法进行元 ...
- Selenium常用API用法示例集----下拉框、文本域及富文本框、弹窗、JS、frame、文件上传和下载
元素识别方法.一组元素定位.鼠标操作.多窗口处理.下拉框.文本域及富文本框.弹窗.JS.frame.文件上传和下载 元素识别方法: driver.find_element_by_id() driver ...
- Selenium:利用select模块处理下拉框
在利用selenium进行UI自动化测试过程中,经常会遇到下拉框选项,这篇博客,就介绍下如何利用selenium的Select模块来对标准select下拉框进行操作... 首先导入Select模块: ...
随机推荐
- 第七篇:使用 CUDA 进行计算优化的两种思路
前言 本文讨论如何使用 CUDA 对代码进行并行优化,并给出不同并行思路对均值滤波的实现. 并行优化的两种思路 思路1: global 函数 在 global 函数中创建出多个块多个线程对矩阵每个元素 ...
- poj_1836 动态规划
题目大意 N个士兵排成一排,不是按照高度顺序排列.现在想要从中去掉几名士兵,从而使得队伍中剩余的士兵能够看到这排最左边或者最右边的那个士兵,某士兵能够看到最左边(或最右边)的士兵指这名士兵和最左边(或 ...
- 获取ScrollView的onScrollListener
scrollView.getViewTreeObserver().addOnScrollChangedListener(new OnScrollChangedListener() { @Overrid ...
- PHP 基础知识代码总结
一.PHP基础语法 变量到数组 <?php //phpinfo(); /* 变量 $a=1;//不分配空间 echo "\$a=".$a; echo "<br ...
- python and 我爱自然语言处理
曾经因为NLTK的 缘故开始学习Python,之后渐渐成为我工作中的第一辅助脚本语言,虽然开发语言是C/C++,但平时的很多文本数据处理任务都交给了Python.离 开腾讯创业后,第一个作品课程图谱也 ...
- python web框架 django 练习1 django 1.11版本
django练习 在我自己项目里创建一个xiaoliu的文件夹 里面创建s1.py 文件 s1.py文件 里面写各种函数 from django.shortcuts import HttpRespon ...
- 使用Django和Python创建Json response
版权声明:本文为博主原创文章,欢迎转载. https://blog.csdn.net/fengyu09/article/details/30785101 使用jquery的.post提交,并期望得到多 ...
- 001-shell基础,创建,运行
一.概述 Shell 是一个用 C 语言编写的程序.Shell 既是一种命令语言,又是一种程序设计语言. Shell 是指一种应用程序,这个应用程序提供了一个界面,用户通过这个界面访问操作系统内核的服 ...
- tp5中nginx配置
首先tp5的访问目录指向到webroot/public文件夹中. thinkphp的url访问:http://serverName/index.php(或者其它应用入口文件)/模块/控制器/操作/[参 ...
- 我的Linux病毒追踪记录
第一次自己一个人全权负责做游戏服务器,对于Linux安全并不太懂,所以就在昨天,服务器遭到了攻击,刚开始,只是发现服务器的带宽占满了,以为是带宽不够用,可是想想,弱联网游戏对带宽占用也不高啊而且带宽加 ...