博客
关于我
自动化测试必备技能之Selenium表格定位
阅读量:101 次
发布时间:2019-02-26

本文共 1844 字,大约阅读时间需要 6 分钟。

前言

浏览器网页常常会包含各类表格,自动化测试工程师可能会经常操作表格中的行,列以及某些特定的单元格,因此熟练掌握表格的定位方法是自动化测试实施过程中必要的技能。

被测试网页的HTML代码

在这里插入图片描述

在这里插入图片描述

一、遍历表格所有单元格

实例代码

1 from selenium import webdriver2 driver = webdriver.Firefox()3 driver.get(r'file:///D:/pythonSeleniumTestCode/pythonStu/src/table.html')4 #id定位方式获取整个表格对象5 table = driver.find_element_by_id('table')6 #通过标签名获取表格中所有行7 trlist = driver.find_elements_by_tag_name('tr')8 print(len(trlist))9 for row in trlist:10 #遍历行对象,获取每一个行中所有的列对象11 tdlist = row.find_elements_by_tag_name('td')12 for col in tdlist:13 print(col.text + '\t',end='')14 print('\n')15 driver.quit()

输出结果

消费项目 一月 二月

衣服 1000元 500元

化妆品 3000元 500元

食物 3000元 650.00元

总计 7000元 1150元

代码说明

1.先获取整个表格的页面对象

table=driver.find_element_by_id(‘table’)

2.在表格页面元素对象中,获取所有tr元素对象,并存储在trlist中

trlist=

table.find_elements_by_tag_name(‘tr’)

3.循环遍历存储表格行对象的trlist对象,每获取一行中所有的单元格对象(存储到tdlist对象中),就循环遍历一次,并将每个单元格的文本内容输出

for row in trlist:

#遍历行对象,获取每一个行中所有的列对象

tdlist = row.find_elements_by_tag_name(‘td’)

for col in tdlist:

print(col.text + ‘\t’,end=’’)

print(’\n’)

以上步骤完成表格中所有单元格的遍历输出,通过遍历可以实现读取任意单元格内容的操作。

二、定位表格中的某个元素

目的

定位表格中第二行第二列单元格

XPATH表达式

//table[@id=‘table’]/tbody/tr[2]/td[2]

python定位语句:

element = driver.find_element_by_xpath(’//table[@id=‘table’]/tbody/tr[2]/td[2]’)

CSS表达式:

table#table>tbody>tr:nth-child(2)>td:nth-child(2)

python定位语句:

element = driver.find_element_by_css_selector(‘table#table>tbody>tr:nth-child(2)>td:nth-child(2)’)

三、定位表格中的子元素

被测试网页HTML代码

在这里插入图片描述
在这里插入图片描述
目的

在被测网页中,定位表格中第三行中的第一个“面霜”文字前的复选框。

//td[contains(.,‘化妆品’)]/input[1]

python定位语句:

element =

driver.find_element_by_xpath(’//td[contains(.,‘化妆品’)]/input[1]’)

代码说明

先找到包含元素的单元格,在此单元格中再寻找子元素即可。表达式//td[contains(.,‘化妆品’)]表示模糊匹配文本内容包含“化妆”关键字的单元格td元素,//input[1]表示定位td下的第一个input子元素。

总结

这篇随笔写的很简单,实际工作中的表定位可能也会有各种各样的情况,但是这篇随笔确实基础,希望大家多练习吧。

一个用心码了这么多文字的人,往往渴望得到大家的认可。如果你觉得这篇文章对你有帮助,双击屏幕,给我点个赞呀!

更多软件测试资源分享微信公众号:【程序员一凡】

软件测试技术交流群:1079636098

在这里插入图片描述

转载地址:http://rxqz.baihongyu.com/

你可能感兴趣的文章
Mysql中的using
查看>>
MySQL中的关键字深入比较:UNION vs UNION ALL
查看>>
mysql中的四大运算符种类汇总20多项,用了三天三夜来整理的,还不赶快收藏
查看>>
mysql中的字段如何选择合适的数据类型呢?
查看>>
MySQL中的字符集陷阱:为何避免使用UTF-8
查看>>
mysql中的数据导入与导出
查看>>
MySQL中的时间函数
查看>>
mysql中的约束
查看>>
MySQL中的表是什么?
查看>>
mysql中穿件函数时候delimiter的用法
查看>>
Mysql中索引的分类、增删改查与存储引擎对应关系
查看>>
Mysql中索引的最左前缀原则图文剖析(全)
查看>>
MySql中给视图添加注释怎么添加_默认不支持_可以这样取巧---MySql工作笔记002
查看>>
Mysql中获取所有表名以及表名带时间字符串使用BetweenAnd筛选区间范围
查看>>
Mysql中视图的使用以及常见运算符的使用示例和优先级
查看>>
Mysql中触发器的使用示例
查看>>
Mysql中设置只允许指定ip能连接访问(可视化工具的方式)
查看>>
mysql中还有窗口函数?这是什么东西?
查看>>
mysql中间件
查看>>
MYSQL中频繁的乱码问题终极解决
查看>>