python+selenium元素的基本操作、.等待操作、iframe操作、
alert弹出框
1元素的基本操作
关键代码 :
点击:ele.click()
输⼊内容:ele.send_keys("内容")
清空内容:ele.clear()
获取⽂本内容:
获取属性值:_attribute("属性名称")
获取元素的宽⾼:ele.size,size和location⼀样都是实例属性,返回都是字典格式
获取元素的坐标:ele.location,元素坐标值是通过元素的最左上⾓相对浏览器内容区域的左上⾓来定位的
# 定位元素
input_ele = driver.find_element_by_id("kw")
su_ele = driver.find_element_by_id("su")
# 获取元素的⽂本内容
# 获取元素的某个属性
_attribute("属性名称")
# 输⼊内容
input_ele.send_keys("selenium")
# 点击操作
su_ele.click()
# 清空内容
input_ele.clear()
# 获取元素的宽⾼
print("【百度⼀下】按钮的宽⾼:{}".format(su_ele.size))
# 获取元素的x、y坐标值
print("【百度⼀下】按钮的坐标:{}".format(su_ele.location))
2表单提交
iframe嵌套页面加载慢关键代码 :
表单提交:ele.submit(),⽤于表单的提交;也可以定位到具体提交按钮做⼀个点击的动作
input_ele = driver.find_element_by_id("kw")
input_ele.submit() # 也可以实现回车
3检查元素
关键代码 :
是否可见:ele.is_displayed(),返回True可见,反之不可见
是否可点击:ele.is_enabled(),返回True可点击,反之不可点击
是否被选中:ele.is_selected(),返回True被选中,反之未选中
ele = driver.find_element_by_id("xxxx")
print(ele.is_displayed())
print(ele.is_enabled())
print(ele.is_selected())
3等待操作
在web⾃动化中,不得不提的元素等待操作,我们在做功能测试中也会经常遇到页⾯元素未完全加载
的情况,需要等到元素出现后再进⾏操作。现在是代码代替⼈⼯去做这件事,那⾃然也需要先等到元素加载完成才进⾏操作。
当我们打开浏览器,进⼊⼀个⽹页(⽹址),除了get()会⾃主强制等待⽹页加载完再进⼊下⼀个操作,其他元素操作都不会⾃⼰等待页⾯加载完成,因此在get()之后只要我们做的动作会让页⾯产⽣变化就要做⼀个等待动作,以防元素未加载完成导致元素不到报错,因为代码运⾏的速度是⾮常快的。
有三种等待⽅式,⼀种强制等待,两种智能等待:隐性和显性。
3|1强制等待
time.sleep(秒):表⽰让程序强制死等x秒,⽆论发⽣什么,都会在x秒之后再执⾏后续的代码
import time
time.sleep(2) # 强制等待10s
3|2隐性等待
implicitly_wait(秒):设置最长等待时间,在这个时间内只要有个时间点加载完成,则执⾏下⼀步代码,如果在这个时间内仍未完成,就会抛出⼀个异常,在这整个driver的会话周期内,设置⼀次即可,全局都可⽤。
缺点 :程序会⼀直等待整个页⾯加载完成,也就是⼀般情况下你看到浏览器标签栏那个⼩圈不再转,才会执⾏下⼀步,但有时候页⾯想要的元素早就加载完成了,但是因为个别js、图⽚之类的东西特别慢,仍得等到页⾯全部完成才能执⾏下⼀步,就会增加不必要的加载时间。from selenium import webdriver
# 实例化chrome类
# 启动了Chromedriver,并与Chromedriver开启了会话
driver = webdriver.Chrome()
driver.implicitly_wait(10)
<("www.baidu")
3|3显性等待
关键代码:WebDriverWait(driver, 等待时长, 轮循周期).until/until_not(判断条件)。
使⽤WebDriverWait类和expected_conditions模块,它会明确等到某个条件满⾜后,再去执⾏下⼀步操作。它的等待机制是程序会每隔xx秒去寻⼀遍,如果条件成⽴则执⾏下⼀步,否则以轮循的⽅式继续去寻,直到超过设置的最长时间,然后抛出⼀个TimeoutException异常。WebDriverWait类:显性等待类
expected_conditions模块,提供了⼀系列期望发⽣的条件,如下:
title_is(title):判断当前页⾯的title是否等于预期,
title_contains(title):判断当前页⾯的title是否包含预期字符串
presence_of_element_located(locator):判断某个元素是否存在dom树
visiblilty_of_element_located(locator):判断某个元素是否可见
visiblilty_of(element):跟上⾯的⽅法⼀样,判断某个元素是否可见,只是前者要传locator(定位器),后者直接传定位到的element就好了 element_to_be_clickable(locator):判断某个元素是否可点击
frame_to_be_available_and_switch_to_it(frame下标/name属性/webelement对象):判断该frame是否可以swtich进去,可以则返回True并swtich进去,否则返回False。
alert_is_present():判断页⾯上是否存在alert
以上是列举的部分条件类,还有更多的⽅法有兴趣可以⾃⾏扩展。下⾯是其中⼀个⽅法⽰例:
import time
from selenium import webdriver
from selenium.webdriver.support.wait import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
from selenium.webdrivermon.by import By # By模块封装了8⼤定位⽅法名
driver = webdriver.Chrome()
# driver.implicitly_wait(10) # 智能等待10秒
<("www.baidu")
driver.find_element_by_xpath('//div[@id="u1"]//a[@name="tj_login"]').click()
# 定位表达式
loc = (By.ID, "TANGRAM__PSP_10__footerULoginBtn") # 实际是11,这⾥改成10不到会弹出报错
# 等待元素可见:等待时间10秒,轮循周期默认0.5秒⼀次
WebDriverWait(driver, 10).until(EC.visibility_of_element_located(loc))
# 操作满⾜条件之后的元素
driver.find_element(*loc).click()
time.sleep(2)
driver.quit()
运⾏结果:
C:\software\ D:/learn/test.py
Traceback (most recent call last):
File "D:/learn/test.py", line 25, in <module>
WebDriverWait(driver, 10).until(EC.visibility_of_element_located(loc))
File "C:\software\python\lib\site-packages\selenium\webdriver\support\wait.py", line 80, in until
raise TimeoutException(message, screen, stacktrace)
Process finished with exit code 1
知识点 :
上⾯提到的定位器其实就是⼀个元组(定位⽅式, 定位表达式),By模块⾥封装了8⼤定位⽅法名,跟我们之前的定位⽅式是⼀样的。
不过要注意的是,在使⽤find_element()定位元素时,不是传⼊⼀个元组,定位⽅式和表达式是直接作为参数传⼊的,因此上⾯的例⼦中会⽤到*解包。⽽find_element_by_id(属性值)之类的定位,底层代
码⽤的其实就是find_element(),后者只要传对应定位⽅式的值,前者则需要传定位⽅式、定位表达式。
4iframe操作
iframe:iframe就是⼀个⽹页⾥⾯嵌套了另外⼀个框架/页⾯,即⼀个html页⾯中,还内嵌了另⼀个html页⾯,这个内嵌的html页⾯放
在<iframe></iframe>标签对中。iframe也是html中的某⼀个元素,⾥⾯放的是html页⾯。
4|1切换到iframe
如果我们要操作的元素,在内嵌的iframe页⾯中,那么必须要从当前页⾯切换到iframe中,然后再去iframe中的页⾯去操作元素。切换到iframe,主要有以下两种⽅式:
⽅式⼀:swtich_to.iframe()
参数:iframe的index(下标)/ iframe的name属性 / iframe的webelement对象
# 切换到iframe 下标/name属性/webelement对象
driver.switch_to.iframe("login_frame_qq")
driver.switch_to.iframe(0)
driver.switch_to.iframe(dirver.find_element_by_tag_name('iframe'))
⽅式⼆:EC.frame_to_be_available_and_switch_to_it()(强烈推荐,等待和切换⼀次到位)
参数:iframe的index(下标)/ iframe的name属性 / iframe的webelement对象,等待条件:此⽅法会判断iframe是否可⽤,并且会⾃动切换到iframe中
wait = WebDriverWait(driver, 10) # 设置显性等待时间
# 设置等待条件,此⽅法会判断iframe是否可⽤,并且会⾃动切换到iframe中
wait.until(EC.frame_to_be_available_and_switch_to_it('login_frame_qq'))
driver.find_element_by_id('switcher_plogin').click()
4|2切换到上层iframe
关键代码:driver.iframe_to.parent_frame()
如果iframe中⼜内嵌了⼀个iframe,那就只能在主html中⼀层⼀层地切进去。如果想返回上⼀层时也是⼀层⼀层地返回去。⼀般很少会返回去。
4|3切换到主html
关键代码:driver.swtich_to.default_content()
切换到iframe之后,本⾝在主html就变成了在切换后的内嵌html,这时可以操作内嵌html的元素了,如果想重新操作主html的元素,就要先从iframe中回到主html。
这⾥要注意,不管你是在第⼏层的iframe中,想切回到主html中,都只需执⾏⼀次。例⼦:
import time
from selenium import webdriver
from selenium.webdriver.support.wait import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
from selenium.webdrivermon.by import By
# 主html、内嵌html
# 确定要操作的元素是否在iframe内?
# 启动Chromedriver,并与Chromedriver开启会话
driver = webdriver.Chrome()
driver.maximize_window()
<("lemon.ke.qq/")
driver.find_element_by_id('js_login').click()
wait = WebDriverWait(driver, 10) # 设置显性等待时间
qq_l = (By.XPATH, '//div[@class="content-btns"]//a')
wait.until(EC.visibility_of_element_located(qq_l)) # 设置显性等待条件
driver.find_element(*qq_l).click()
# 设置等待条件,此⽅法会判断iframe是否可⽤,并且会⾃动切换到iframe中
wait.until(EC.frame_to_be_available_and_switch_to_it('login_frame_qq'))
driver.find_element_by_id('switcher_plogin').click()
driver.find_element_by_id('u').send_keys('test')
driver.find_element_by_id('p').send_keys('test')
driver.find_element_by_id('login_button').click()
time.sleep(2)
driver.quit() # 关闭浏览器,kill掉chromedriver进程
5alert弹出框操作
⽹页上的弹出框分两种,⼀种是页⾯弹出框,这是⼀个html页⾯元素,可见时是能定位到并进⾏操作的;另⼀种则是alert弹出框,这是是js ⾥的alert弹框,⽽selenium只能定位到html元素,那么像这种alert弹出框如何处理呢?既然是js那么我们就⽤js来处理。
5|1页⾯弹出框
它是⼀个html页⾯元素,只是需要由⽤户在页⾯的操作中触发弹出,因此处理这种类型的弹出框,⼀般分为两步: 第⼀步:执⾏触发操作之后,等待弹出框出现
第⼆步:定位弹出框中的元素并操作
如百度登录的弹出框:
import time
from selenium import webdriver
from selenium.webdriver.support.wait import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
from selenium.webdrivermon.by import By # By模块封装了8⼤定位⽅法名
driver = webdriver.Chrome()
<("www.baidu")
driver.find_element_by_xpath('//div[@id="u1"]//a[@name="tj_login"]').click()
# ⽤户名登陆定位表达式
loc = (By.ID, "TANGRAM__PSP_11__footerULoginBtn")
# 等待时间10秒,轮循周期默认0.5秒⼀次
WebDriverWait(driver, 10).until(EC.visibility_of_element_located(loc))
# 操作满⾜条件之后的元素
driver.find_element(*loc).click()
time.sleep(2)
driver.quit()
5|2alert弹出框
alert弹出框的处理⽅式:
第⼀步:使⽤swtich_to.alert切换到弹出框,建议先使⽤显性等待EC.alert_is_present()判断弹出框是否可见,或者强制等待
0.5s:time.sleep(0.5)
第⼆步:使⽤Alert类提供的⼀系列操作⽅法对弹窗进⾏操作:
accept()是
dismiss()否
Send_keys()往弹出框⾥输⼊⽂本
text()获取弹框⾥的内容
import time
from selenium import webdriver
from selenium.webdriver.support.wait import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
# 启动Chromedriver,并与Chromedriver开启会话
driver = webdriver.Chrome()
driver.maximize_window()
<("www.w3school/tiy/t.asp?f=js_alert")
wait = WebDriverWait(driver, 10)
wait.until(EC.frame_to_be_available_and_switch_to_it('iframeResult'))
# 触发alert弹框
driver.find_element_by_xpath('//button[text()="试⼀试"]').click()
wait.until(EC.alert_is_present())
time.sleep(3) # 这⾥是为了看下效果
alert = driver.switch_to.alert # Alert类的实例化
alert.accept() # 是
# dismiss() 否
# text() 获取弹框⾥的内容
# Send_keys() 往弹出框⾥输⼊⽂本
driver.quit()
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论