selenium 表格和导航菜单

对于一款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])

 

posted @ 2021-12-15 16:07  超级宝宝11  阅读(277)  评论(0编辑  收藏  举报