本篇文章给大家谈谈selenium获取表格行数,以及selenium获取select选中的值对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。
本文目录一览:
- 1、selenium java怎么取出excel内容
- 2、selenium怎么获取了表格所有行
- 3、selenium如何处理table 如何实现勾选红框标注的那条数据
- 4、selenium之webdriver详解——小白进阶之路(二)
- 5、Selenium处理常见web控件-table
- 6、python selenium如何点击页面table列表中的元素
selenium java怎么取出excel内容
import java.io.File;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import jxl.Sheet;
import jxl.Workbook;
/*
* 获取Excel文件的内容,使用Workbook方式来读取excel
*/
public class ExcelWorkBook {
//利用list集合来存放数据,其类型为String
private Liststring list=new ArrayList/stringstring();
//通过Workbook方式来读取excel
Workbook book;
String username;
/*
* 获取excel文件第一列的值,这里取得值为username
*/
public List/stringstring readUsername(String sourceString) throws IOException,Exception{
List/stringstring userList = new ArrayList/stringstring();
try {
Workbook book =Workbook.getWorkbook(new File(sourceFile));
Sheet sheet=book.getSheet(0);
//获取文件的行数
int rows=sheet.getRows();
//获取文件的列数
int cols=sheet.getColumns();
//获取第一行的数据,一般第一行为属性值,所以这里可以忽略
String col1=sheet.getCell(0,0).getContents().trim();
String col2=sheet.getCell(1,0).getContents().trim();
System.out.println(col1+","+col2);
//把第一列的值放在userlist中
for(int z=1;zrows ;z++){
String username=sheet.getCell(0,z).getContents();
userList.add(username);
}
} catch (Exception e) {
e.printStackTrace();
}
//把获取的值放回出去,方便调用
return userList;
}
/*
* 获取excel文件第二列的值,这里取得值为password
*/
public ListString readPassword(String sourceString) throws IOException,Exception{
Liststring passList = new ArrayList/stringstring();
try {
Workbook book =Workbook.getWorkbook(new File(sourceFile));
Sheet sheet=book.getSheet(0);
int rows=sheet.getRows();
for(int z=1;zrows ;z++){
String password=sheet.getCell(1,z).getContents();
passList.add(password);
}
} catch (Exception e) {
e.printStackTrace();
}
return passList;
}
public ListString getList(){
return list;
}
}
selenium怎么获取了表格所有行
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
!DOCTYPE HTML
html
head
meta charset=UTF-8 /
titleNothing/title
style type="text/css"
/style
script type="text/javascript" src="jquery-1.8.0.min.js"/script
script type="text/javascript"
$ (function ()
{
$ ('table tr td').each (function ()
{
alert (this.innerHTML);
})
})
/script
/head
body
/body
/html
selenium如何处理table 如何实现勾选红框标注的那条数据
给你一个实现的方案:假设这个table的id为“table”
public void clickName(String name){
//获取table的总行数
//如果/table/tbody中的tr有class属性为"tr",且在tbody之外没有控件的class属性是这个
int rowNum = driver.findElements(By.className("tr")).size();
//如果没有上面那个条件,则使用tagName获取tbody内的行数
int rowNum = driver.findElement(By.xpath("//table[@id = 'table']/tbody"))
.findElements(By.tagName("tr")).size();
//循环获取每一行的姓名,和传入的Name比较,是的话勾选方括号
for(int i = 1;i=rowNum;i++){
String rowName = driver.findElement(By.xpath("//table[@id='table']/tbody/tr["+i+"]")/td[3])).getText();
if(name.equals(rowName)){
driver.findElement("//table[@id='table']/tbody/tr["+i+"]")/td[1])).click();
break;
}
}
}
//大概的代码应该是这样,太久没写了,如果点击名字可以勾选到的话实现起来就更加简单。
selenium之webdriver详解——小白进阶之路(二)
笔记:
01.设置元素等待时间
自动化测试的时候,元素定位没有错,但是跑脚本的时候却报错了
例如,登录的时候要等登录页面加载出来才能输入用户名和密码
selenium设置元素等待时间的3种方式及区别
1.sleep() --固定等待时间:强制等待,不能把握准确的等等时间,适合调试时用
2.implicitly_wait() --隐式等待时间:等页面加载完成才执行下一步操作,一般设置一次即可
3.WebDriverWait --显示等待时间:配合untill()和not untill()方法,根据判断条件 灵活处理等待时间
要先设置一个超长时间,在这个时间内,程序根据调用频率每隔几秒查看一下,如果条件满足,则执行下一步操作,若不满足且超过了等待时间则抛出异常
导包:from selenium.webdriver.support.ui import WebDriverWait
使用:WebDriverWait(driver, 超时时间, 调用频率, 要忽略的异常).until(要执行的方法, 超时时返回的错误信息)
实例:
replace:
02.键盘事件Keys类
制表符:send_keys(Keys.TAB)
退出键:send_keys(Keys.ESCAPE)
F1:send_keys(Keys.F1) f1~f12 以此类推
03.二次定位
顾名思义,通过多个元素,定位两次
dr.find_element(By.CLASS_NAME,"s_input").send_keys("python")
二次定位:
dr.find_element(By.NAME,"query").find_element(By.CLASS_NAME,"s_input").send_keys("python")
04.selenium鼠标悬停类-- ActionChains()
导包:from selenium.webdriver.common.action_chainsimport ActionChains
实例:将鼠标移动至更多设置,悬停鼠标
elem1= dr.find_element(By.LINK_TEXT,"设置")
ActionChains(dr).move_to_element(elem1).perform()
05.selenium警告框的处理
很多web应用经常会遇到JavaScript编写的alert 、confirm 以及prompt 弹窗,需要用到switch_to.alert来切换弹窗,并对弹窗进行输入信息,关闭等处理。
switch_to.alert.text --获取弹窗文本信息
switch_to.alert.accept() --点击弹窗中确定按钮
switch_to.alert.dismiss() --点击弹出中取消按钮
switch_to.alert.sendKeys("字符串") --在弹窗中输入信息
实例:
06.下拉菜单选择的三种方式
导包:from selenium.webdriver.support.uiimport Select
#选择下拉框的o2
elem1 = dr.find_element(By.ID,"s3Id")
1:根据value值定位
Select(elem1).select_by_value("o2val")
2.根据index定位
Select(elem1).select_by_index(1)
3.根据下拉框文本信息定位
Select(elem1).select_by_visible_text("o2")
07.多窗口切换
window_handles --获取所有窗口句柄
switch_to.window(指定窗口) --切换到指定窗口
08.selenium之JS操作浏览器滚动条位置
execute_script("window.scrollTo(0,n);")
09.selenium之JS操作隐藏元素
隐藏元素的标识:style="display:none;"
一般我们通过将隐藏元素的属性修改成显示再定位
10.操作excel文件
将测试数据参数化用到
10.1准备参数化数据文件
10.2导包
打开文件,填写文档路径
运行结果:
定位到sheet的位置
读取sheet的行和列的内容
#读取表的行的方法
rows = sheet1.nrows
print("行数",rows)
columns = sheet1.ncols
print("列数",columns)
读取指定行的值
#读取指定行的值
rowValue1 = sheet1.row_values(0)
print(rowValue1)
#读取指定列的值
colValue1 = sheet1.col_values(0)
print(colValue1)
#输出所有用户名和对应的密码
for iin range(1,rows):
print("用户名:" + sheet1.row_values(i)[0] +",密码:" + sheet1.row_values(i)[1])
Selenium处理常见web控件-table
Selenium没有提供table的处理方法,只有根据需要自己编写脚本。主要思路是通过xpath下标和css selector层级的方式,通过循环实现根据行列取数据,根据数据判断所在的行列。
一个简单的table示例:
大致是这样一个表格:
现在表格可能会加多种样式等情况,需要根据实际测试的页面表格情况灵活调整。
再封装一下,封装成一个类:
python selenium如何点击页面table列表中的元素
1.通过selenium定位方式(id、name、xpath等方式)定位table标签
#html源码table
border="5"
id="table1"
width="80%"#selenium操作代码table1=driver.find_element_by_id('table1')
2.获取总行数(也就是获取tr标签的个数)
#html源码trth姓名/thth性别/th/tr#selenium操作源码
table_rows
=
table1.find_elements_by_tag_name('tr')
3.获取总列数(也就是tr标签下面的th标签个数)
#html源码trth姓名/thth性别/th/tr#selenium操作源码:第一个tr标签下有多少个th
table_rows
=
table_rows[0].find_elements_by_tag_name('th')
4.获取单个cell值
#selenium操作源码:第一行第二列的text值row1_col2
=
table_rows[1].find_elements_by_tag_name('td')[1].text
5.取值比对~
selenium获取表格行数的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于selenium获取select选中的值、selenium获取表格行数的信息别忘了在本站进行查找喔。
2、本站永久网址:https://www.yuanmacun.com
3、本网站的文章部分内容可能来源于网络,仅供大家学习与参考,如有侵权,请联系站长进行删除处理。
4、本站一切资源不代表本站立场,并不代表本站赞同其观点和对其真实性负责。
5、本站一律禁止以任何方式发布或转载任何违法的相关信息,访客发现请向站长举报
6、本站资源大多存储在云盘,如发现链接失效,请联系我们我们会第一时间更新。
源码村资源网 » selenium获取表格行数(selenium获取select选中的值)
1 评论