python selenium操作表格式元素实例

很多时候,网页上的布局都是表格形式的,如出下面这样的

这种网页类型在自动化中比较头痛,需要很多判断,下面就举个例子,这里以深圳出入境网页为例,http://yysl.sz3e.com/wsyysq/select_sldw_zbs.jsp

比如我们需要点击某个星期六的任意一个可以预约的时段,该怎么写呢。

首先我们要分析,这也是写程序的第一步,将手工操作进行逻辑提取,再形成程序

1、先判断列表中的日期,找到星期六的列

2、再从找到的列中判断可预约的时间点

基本思路就是这样,来看第一点,怎么提取表格式的日期时间呢?

使用firepath看看

所以可以用current找到所有的id,xpath://label[@class=‘current‘]


接下来怎么把一列数据找出来呢?

从html中可以看到这是一个标准的w3c 表格形式

可以使用以下方式将一列数据定位出来

//tbody[@id=‘timeline‘]/tr/td[1]   其中1表示第1列,可根据需要拿出对应的列

因次,基本的代码如下:

all_data=browser.find_elements(By.XPATH, "//label[@class=‘current‘]")   #把所有日期元素对像选取出来

rowall=[rowall.text for rowall in all_data]  #把对应的日期元素取出

rowindex=[rowall.index(i) for i in rowall if u‘星期六‘ in i]  #获取列

‘‘‘
判断周六是否可预约,没有隔2s刷新
‘‘‘
while True:
    tds=browser.find_elements(By.XPATH,"//tbody[@id=‘timeline‘]/tr/td[%d]" % (rowindex[0]+1))
    if [td for td in tds if "可预约" in td.text]:break
    else:
        browser.find_element_by_xpath("//span[@receivepointsid=‘440307000000‘]").click()
        time.sleep(2)

.....
时间: 2024-08-07 16:46:08

python selenium操作表格式元素实例的相关文章

【selenium学习笔记一】python + selenium定位页面元素的办法。

1.什么是Selenium,为什么web测试,大家都用它? Selenium设计初衷就是为web项目的验收测试再开发.内核使用的是javaScript语言编写,几乎支持所以能运行javaScript的浏览器,支持windows\linux\macos等各种平台. Selenium 脚本是用多种受支持的编程语言中的一种编写的 —— 目前可用的有 Java.Ruby 和 Python 驱动程序.这些脚本在浏览器之外的一个单独的进程中运行.驱动程序的任务是执行测试脚本,并通过与运行在浏览器中的 bro

python + selenium定位页面元素的办法

1.什么是Selenium,为什么web测试,大家都用它? Selenium设计初衷就是为web项目的验收测试再开发.内核使用的是javaScript语言编写,几乎支持所以能运行javaScript的浏览器,支持windows\linux\macos等各种平台. Selenium 脚本是用多种受支持的编程语言中的一种编写的 -- 目前可用的有 Java.Ruby 和 Python 驱动程序.这些脚本在浏览器之外的一个单独的进程中运行.驱动程序的任务是执行测试脚本,并通过与运行在浏览器中的 bro

python selenium中等待元素出现及等待元素消失操作

在自动化测试中,很多时候都会有等待页面某个元素出现后能进行下一步操作,或者列表中显示加载,直到加载完成后才进行下一步操作,但时间都不确定,如下图所示 幸运的是,在selenium 2后有一个模块expected_conditions,里面有很多函数可以完成这个工作,相关博客可见 http://www.cnblogs.com/nbkhic/p/4885041.html 但在selenium 1中或自己仅仅想写个简单用法该怎么处理那?解决如下: from selenium.common.except

Python +selenium之设置元素等待

当浏览器在加载页面时,页面上的元素可能并不是同时被加载完成,这给元素的定位增加了困难.如果因为在加载某个元素时延迟而造成ElementNotVisibleException 的情况出现,那么就会降低自动化脚本的稳定性,我们可以设置元素等待时间改善这种问题造成的不稳定性. WebDriver提供了两种类型的等待,显示等待和隐式等待  显示等待: 显示等待使WebDriver等待某个条件成立时继续执行,否者在达到最大时长事会抛出超时异常(TimeoutException)

Python+Selenium 定位页面元素

1.跳转到Frame/Iframe ,再定位元素理解:frame的实质,frame中实际上是嵌入了另一个页面,而webdriver每次只能在一个页面识别,因此需要先定位到相应的frame,对那个页面里的元素进行定位 1.1方法一如果iframe有name或id的话,直接使用switch_to_frame("name值")或switch_to_frame("id值").如下:driver=webdriver.Firefox()driver.get(r'http://w

python selenium 元素定位(三)

上两篇的博文中介绍了python selenium的环境搭建和编写的第一个自动化测试脚本,从第二篇的例子中看出来再做UI级别的自动化测试的时候,有一个至关重要的因素,那就是元素的定位,只有从页面上找到这个元素,我们从能对这个元素进行操作,那么我们下来看看如何来定位元素. selenium 提供了8中元素定位的方法(大家要学习元素的定位,首先可以学习下前端的基础知识,这样有利于我们学习自动化测试,大家可以看一下:http://www.runoob.com/) find_element_by_id

【转载】【selenium+Python WebDriver】之元素定位

总结: 感谢"煜妃"<Selenuim+Python之元素定位总结及实例说明>和"Huilaojia123"<selenium WebDriver定位元素学习总结>的文章

python selenium系列(四)元素等待

一 前言 在前面的selenium系列(二)元素定位方式和selenium系列(三)常用操作类型及方法两节中,已经介绍了web页面元素的识别定位.操作等技术,可能你会觉得掌握这两项技术就可以实施web自动化了,答案基本是这样的,毕竟元素定位和操作是核心技术.但是,在某些场景,脚本的运行并非预期那样,如,要操作的元素用常规方法无法识别.元素可以识别但在脚本运行时却未如期而至等.为了解决这些疑难杂症,接下来三节内容将会介绍处理这些问题的通用方法. 在本节,主要介绍元素等待的使用方法和场景,该方法是开

python+selenium自动化环境配置及使用实例

一.搭建环境相关地址以及相关模块下载地址 1.#各个浏览器驱动下载地址: https://www.cnblogs.com/nancyzhu/p/8589764.html 2.#sublime+python+selenium自动化配置教程: http://python.tedu.cn/know/289803.html 3.#html测试报告: https://github.com/defnngj/HTMLTestRunner         http://www.testpub.cn/t/213