TA的每日心情 | 擦汗 3 天前 |
---|
签到天数: 1042 天 连续签到: 4 天 [LV.10]测试总司令
|
对于一款web产品,页面中经常使用表格展示数据。同一个web产品,多个页面之间的表格,一般都是行列有差异,但是表格的构成元素以及样式类别都是相同的。
1、便利操作
这种情况下,可以定义一个表格类,使用页面表格的定位字符串进行初始化,提供一些便利操作。
比如根据"申请号=166",找到对应的"申请时间"为"2021-12-15 08:41:14"
实现思路为:
根据表格定位字符串,找到表格的title行,title行的多个单元格内容组成一个列表,列表内容为:申请号、申请人、接收人、申请时间、数据流程、审批流程、文件名。
根据表格定位字符串,找到表格的body,即数据区域,body是多行组成的一个列表。每一行又是由多个单元格组成的一个列表。所以body是一个二维列表。
通过文本内容进行匹配,确定了“申请时间”为第4列,即目标单元在第4列。
通过“申请号=166”,确定了目标单元在第3行。
所以目标单元格为body[3][4]对应的页面元素。
代码实现如下:
- class Table():
- def __init__(self,driver,locator_type="class name",table_locator="v-table-class"):
- self.table = driver.find_element(locator_type,table_locator)
- self.table_title = self.table.find_element_by_class_name("v-table-title-class")
- self.table_body = self.table.find_element_by_class_name("v-table-body-class")
- self.table_title_cells = self.table_title.find_elements_by_tag_name("td")
- self.table_body_rows = self.table_body.find_elements_by_tag_name("tr")
- self.table_body_cells = []
- for tr in self.table_body_rows:
- self.table_body_cells.append(tr.find_elements_by_tag_name("td"))
- self.table_title_cells_text = []
- for td in self.table_title_cells:
- self.table_title_cells_text.append(td.get_attribute("innerText"))
- def filter(self,col1_title,col1_value,col2_title):
- assert col1_title in self.table_title_cells_text
- assert col2_title in self.table_title_cells_text
- col1 = self.table_title_cells_text.index(col1_title)
- col2 = self.table_title_cells_text.index(col2_title)
- row = None
- for j in range(len(self.table_body_cells[col1])):
- if col1_value == self.table_body_cells[j][col1].get_attribute("innerText"):
- row = j
- assert row != None
- return self.table_body_cells[row][col2]
复制代码 使用举例: 查找申请号=166对应的文件名,代码如下:
- table_approval_records = Table(driver)
- ele = table_approval_records.filter("申请号","166","文件名")
复制代码 找ele元素后,可以通过ele.get_attribute("innerText")获取元素文本或者执行点击操作。
2、优化方向
目前只支持通过一列的数据进行过滤获取一列的数据。可以扩展为通过多列数据进行过滤,返回多列的数据。
3、导航菜单
方式一:使用selenium点击定位元素,在各个页面间跳转。成本高。
方式二:直接访问各个页面的地址,在各个页面间跳转。方便快捷。
- class Menu():
- def __init__(self,driver,address="192.168.11.171"):
- self.navigation = {
- "zong_lan_mian_ban":"https://{address}/#/dashboard/dhdlinks/system".format(address=address),
- "shen_pi_shen_qing":"https://{address}/#/approval/management".format(address=address),
- "shen_pi_liu_cheng":"https://{address}/#/process/flows".format(address=address),
- "shen_pi_ji_lu":"https://{address}/#/approval/history".format(address=address),
- "shen_pi_she_zhi":"https://{address}/#/approval/approval_setting/email_setting".format(address=address)
- }
- self.driver = driver
- def goto(self,submenu):
- self.driver.get(self.navigation[submenu])
复制代码
|
|