肝万字,带你走进selenium,10天从0-1硬核知识(上)

这篇具有很好参考价值的文章主要介绍了肝万字,带你走进selenium,10天从0-1硬核知识(上)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

4、find_element_by_xpath()

xpath是一种万能的定位方式,当时也有不好的地方,比如下述的例子,一个xpath定位代码很短,一个却很长,所以 ,有其他定位方式的时候优先选择。

肝万字,带你走进selenium,10天从0-1硬核知识(上),程序员,selenium,测试工具

肝万字,带你走进selenium,10天从0-1硬核知识(上),程序员,selenium,测试工具

from selenium import webdriver

fox = webdriver.Firefox()

fox.get(‘https://www.taobao.com/’)

fox.find_element_by_xpath(‘//*[@id=“q”]’).send_keys(‘python’)

fox.find_element_by_xpath(‘/html/body/div[2]/div/div/div[2]/div/div[1]/div[2]/form/div[1]/button’).click()

5、find_element_by_tag_name()

这个定位方式很少用到,用来定位元素标签的,而元素标签定位起来范围较广,定位效率低,什么样的是元素标签,如input,div,li,ul等,这些在一个页面中出现概率极为频繁。这里就不为大家解释图了,直接上代码,写法类似。下属代码只是示例代码不是实例!!!

from selenium import webdriver

fox = webdriver.Firefox()

fox.get(‘https://www.taobao.com/’)

fox.find_elements_by_tag_name(‘input’).send_keys(‘python’)

6、find_element_link_text()

这个方法可以更具文本来定位,但是需要一个较为完整的一段文字

肝万字,带你走进selenium,10天从0-1硬核知识(上),程序员,selenium,测试工具

在这里定位一个新闻:

from selenium import webdriver

driver = webdriver.Firefox()

driver.get(‘http://news.baidu.com/’)

driver.find_element_by_link_text(‘广州地铁十三号线二期西洲站封顶’).click()

7、find_element_by_partial_link_text()

这个方法可以更具文本来定位,并且只需要较为关键的文字即可,同上述有所区别,但是也有些相似。

肝万字,带你走进selenium,10天从0-1硬核知识(上),程序员,selenium,测试工具

在这里定位一个热点要闻。热点要闻图片会被禁掉所以这里就不那么…你们懂的。

from selenium import webdriver

driver = webdriver.Firefox()

driver.get(‘http://news.baidu.com/’)

driver.find_element_by_partial_link_text(‘共同和谱写’).click()

8、find_element_by_css_selector()

css定位也是也不错的东西,我个人认为可以适当的使用。

肝万字,带你走进selenium,10天从0-1硬核知识(上),程序员,selenium,测试工具

from selenium import webdriver

driver = webdriver.Firefox()

driver.get(‘https://www.taobao.com/’)

driver.find_element_by_css_selector(‘#q’).send_keys(‘python’)

elements系列


id find_elements_by_id()
name find_elements_by_name()
class_name find_elements_by_class_name()
xpath find_elements_by_xpath()
tag_name find_elements_by_tag_name()
link_text find_elements_link_text()
partial_link_text find_elements_by_partial_link_text()

css_selector

find_elements_by_css_selector()

显而易见elements定位与element的定位方式有一些细微的区别,举一个例子,其用法相差不大。这里需要用到列表取值,也就是索引值。我定位hao123:

肝万字,带你走进selenium,10天从0-1硬核知识(上),程序员,selenium,测试工具

from selenium import webdriver

driver = webdriver.Firefox()

driver.get(‘https://www.baidu.com/’)

driver.find_elements_by_class_name(‘mnav’)[1].click()

对于元素组定位我不建议使用xpath等指定定位方法,更建议去定位一个标签的元素名,然后通过列表取值,不过没关系,后面学习的内容经过结合使用,你可以想用什么定位就用什么定位,对于上述例子而已你可以使用鼠标定位的方式去进行点击,使用JS或者jQuery的方式进行点击。

JS元素定位


JS定位也是一个不错的方法,就是麻烦了点,不过也是比较实用的。

先看基础的:

1. 获取内部宽高属性:innerHeight,innerWidth 单位:px(像素) 内部宽高:是指除去菜单栏、工具栏、边框等占位元素后,用于显示网页的净宽高 • window.innerHeight - 浏览器窗口的内高度(以像素计) • window.innerWidth - 浏览器窗口的内宽度(以像素计)

2. 获取外部宽高属性:outerHeight,outerWidth 单位:px(像素) • window.outerHeight 浏览器窗口的外部高度(以像素计) • window.outerWidth 浏览器窗口的外部宽度(以像素计)

from selenium import webdriver

fox = webdriver.Firefox()

fox.get(‘https://baidu.com’)

打印内宽,内高

js_ih = ‘return window.innerHeight’

js_iw = ‘return window.innerWidth’

i = fox.execute_script(js_ih)

o = fox.execute_script(js_iw)

print(i,o)

上述代码使用看JS代码打印出了内宽、高,也可以打印外框高,但是需要使用专门的JS写法。需要给定一个返回值,并使用execute_script()进行处理。

另外还有一些其他的操作,如:

新窗口打开链接,此操作与fox.get类似,但是是在原来的基础上打开一个新的窗口

js = “window.open(‘http://baidu.com’)”

关闭一个新的窗口

js_c = ‘window.close()’

fox.execute_script(js_c)

window.location 对象

window.location 对象可不带 window 前缀书写

1. window.location.href 返回当前页面的 href (URL)

2. window.location.hostname 返回 web 主机的域名

3. window.location.pathname 返回当前页面的路径或文件名

4. window.location.protocol 返回使用的 web 协议(http: 或 https:)

5. selenium执行js语句

• driver.execute_script(js) js:就是值js的语句

• 要想获得js的返回值,必须在js语句前加上return

• js_url= “return location.href” • baidu_url=driver.execute_script(js_url)

上述这些,主要用于判断或验证某些标题,地址等可以用到:

from selenium import webdriver

driver = webdriver.Firefox()

driver.get(‘https://baidu.com/’)

#存储所有的js语句

js1=[‘return location.href’,‘return location.hostname’,‘return location.port’,‘return location.title’]

#获取url

url=driver.execute_script(js1[0])

#获取域名

hostname=driver.execute_script(js1[1])

#获取port,返回URL服务器使用的端口号

port=driver.execute_script(js1[2])

#获取title

title1=driver.execute_script(js1[3])

print(“url:{}\nhostname:{}\nport:{}\ntitle:{}”

.format(url,hostname,port,title1))

我将想要获取的值存入了一个列表,通过列表取值的方法拿到对应想要的值。

location的对象方法

indow.location 对象可不带 window 前缀书写

1. location.assign(url) 加载新页面

2. location.reload() 重新加载当前页面,刷新

3. location.replace(url) 用输入的url替换当前的url

assign与replace的区别:

1. location.assign(url) : 加载 URL 指定的新的 HTML 文档。就相当于一个链接,跳转到指定的url,当前页 面会转为新页面内容,可以点击后退返回上一个页面。

2. location.replace(url) : 通过加载 URL 指定的文档来替换当前文档,这个方法是替换当前窗口页面,前 后两个页面共用一个窗口,所以是没有后退返回上一页的

用法介绍

js_left_r = ‘window.location.reload()’

fox.execute_script(js_left_r)

元素定位

id定位:document.getElementById()

name定位:document.getElementsByName()

tag定位:document.getElementsByTagName()

class定位:document.getElementsByClassName()

css定位:document.querySelectorAll()

对于定位,JS与CSS这两者不做推荐,在合适的时候使用合适的方法就好,能精准的定位,完成项目所需才是重点:这里也是拿百度搜索界面举的例子,用的是JS语法,我个人觉得元素定位用JS属实有些麻烦,但是JS在特定的时候还是挺方便的。

from selenium import webdriver

fox = webdriver.Firefox()

fox.get(‘http://baidu.com’)

js_input = “document.getElementById(‘kw’).value=‘python’”

fox.execute_script(js_input)

jx_click = “document.getElementById(‘su’).click()”

fox.execute_script(jx_click)

于其他的doucument.getElementsByName()等元素等位方法,唯一特殊的就是doucument.querySelectorAll(),这个于selenium的css元素定位相似,都是通过css选择器定位。这里定位后获取该元素的文本值。

doucument.querySelectorAll()

肝万字,带你走进selenium,10天从0-1硬核知识(上),程序员,selenium,测试工具

from selenium import webdriver

fox = webdriver.Firefox()

fox.get(‘https://baidu.com’)

获取当前页面的标题

i = fox.execute_script(‘return document.title’)

print(i)

获取该元素的文本值

js_input = ‘return document.querySelector(“a.mnav:nth-child(1)”).textContent’

i = fox.execute_script(js_text)

print(i)

document.getElementsByClassName

肝万字,带你走进selenium,10天从0-1硬核知识(上),程序员,selenium,测试工具

这里可以看到它的class属性,也可以定位标签span,看个人爱好,两者不论用JS哪种方法都需要索引取值,如果说你觉的太麻烦就用doucument.querySelectorAll(),右击选择CSS选择器吧,这是万能的然而也不是万能的,后续慢慢体会,不过推荐对于没有id/name/classname属性使用。

from selenium import webdriver

fox = webdriver.Firefox()

fox.get(‘https://baidu.com’)

js_text = “return document.getElementsByClassName(‘title-content-title’)[0].click()”

fox.execute_script(js_text)

更改元素属性值

1. document.getElementById(‘kw’).autocomplete= ‘off’ --常用元素属性修改

2. document.getElementById(‘vip’).style.visibility= ‘visible’ --设置元素的隐藏属性,是否显示visibility:hidden(隐藏),visible(显示) display : none(隐藏),block(显示)

4. document.querySelector(‘#train_date’).readOnly=false --修改元素的只读属性

修改元素属性值及其文本值

肝万字,带你走进selenium,10天从0-1硬核知识(上),程序员,selenium,测试工具

from selenium import webdriver

fox = webdriver.Firefox()

fox.get(‘https://baidu.com’)

s_input = “return document.querySelector(‘a.mnav:nth-child(1)’).text = ‘NEWS’”

fox.execute_script(s_input)

js_input = “document.getElementById(‘kw’).autocomplete=‘on’”

fox.execute_script(js_input)

肝万字,带你走进selenium,10天从0-1硬核知识(上),程序员,selenium,测试工具

隐藏天猫的图标:

肝万字,带你走进selenium,10天从0-1硬核知识(上),程序员,selenium,测试工具

from selenium import webdriver

fox = webdriver.Firefox()

fox.get(‘https://www.tmall.com/’)

tm = “document.querySelector(‘.tmall-logo-img’).style.display=‘none’”

fox.execute_script™

12306出发日期只读可选,修改成可写,

肝万字,带你走进selenium,10天从0-1硬核知识(上),程序员,selenium,测试工具

注意大小写,readOnly

from selenium import webdriver

fox = webdriver.Firefox()

fox.get(‘https://www.12306.cn/’)

tm = “document.getElementById(‘train_date’).readOnly=false”

fox.execute_script™

肝万字,带你走进selenium,10天从0-1硬核知识(上),程序员,selenium,测试工具

页面滚动条

因为如果页面没有完全显示,element如果是在下拉之后才能显示出来,只能先滚动到该元素才能进 行click,否则是不能click

1. document.body.scrollHeight 获取对象的滚动高度

2. document.body.scrollWidth 获取对象的滚动宽度

3、window.scrollTo(x,y) 方法可把内容滚动到指定的坐标。

动到页面底部

1. 左下角:window.scrollTo(0,document.body.scrollHeight)

2. 右下角:window.scrollTo(document.body.scrollWidth,document.body.scrollHeight)

3. 指定位置:window.scrollTo(0,数值)

4. 滑动到指定元素:ele.srollIntoView() true:与元素顶部对其,false:与元素底部对齐

document.querySelector(‘’).scrollIntoView(false)

from selenium import webdriver

fox = webdriver.Firefox()

fox.get(‘https://www.taobao.com/’)

fox.maximize_window()

打印页面高度

js_height = “return document.body.scrollHeight”

height = fox.execute_script(js_height)

print(height)

打印页面宽度

js_width = “return document.body.scrollWidth”

width = fox.execute_script(js_width)

print(width)

下滑1000px

js_left = “window.scrollTo(0,1000)”

fox.execute_script(js_left)

下滑最底部

jx_left_down = “window.scrollTo(0,document.body.scrollHeight)”

fox.execute_script(jx_left_down)

下滑到指定元素

jx_left_zd = “document.querySelector(‘ul.list > a:nth-child(3) > div:nth-child(1) > div:nth-child(2)’).scrollIntoView(false)”

fox.execute_script(jx_left_zd)

如果是页面内部的滚动条,那就直接上元素定位,ele是元素定位赋的变量。这里实在没找到例子,了解一下。

1. ele.scrollHeight # 获取滚动条高度

2. ele.scrollWidth # 获取横向滚动条宽度

3. ele.scrollTo(x,y) #滑动到指定坐标位置

4. ele.scrollTop=1000 #控制纵向滚动条位置,距离y轴原点的距离

5. ele.scrollLeft=1000 # 控制横向滚动条位置,距离x轴原点的距离

等待时间

====

等待时间有三类,隐式等待,显示等待,强制等待,各有个的好处,且可以搭配使用,等待时间的统一好处就是帮助你更好的定位元素,有时候网络慢了,元素没有加载出来,或者想看看具体的点击操作等,等待时间都可以帮助你解决。

隐式等待不需要额外导包,强制等待与显示等待需要额外导包,看例子

强制等待


最简单的一种办法就是强制等待sleep(X),强制让浏览器等待X秒,不管当前操作是 否完成,是否可以进行下一步操作,都必须等X秒的时间。

import time

from selenium import webdriver

fox = webdriver.Firefox()

fox.get(‘http://www.baidu.com’)

强制等待2S

time.sleep(2)

退出浏览器

fox.quit()

这里新介绍了一个方法,.quit(),退出的意思,这里导入了一个time,用去强制等待2S,2S后自动退出浏览器。强制等待还有一种写法,较为简便:

from time import sleep

from selenium import webdriver

fox = webdriver.Firefox()

fox.get(‘http://www.baidu.com’)

强制等待2S

sleep(2)

退出网址

fox.quit()

效果是一样的,在后续就不需要每次都time.sleep()了。

缺点:

1. 不能准确把握需要等待的时间(有时操作还未完成,等待就结束了,导致报错;有时操作已经 完成了,但等待时间还没有到,浪费时间)

2. 如果在用例中大量使用,会浪费不必要的等待时间,影响测试用例的执行效率。

优点:

1. 使用简单,可以在调试时使用

隐式等待


对其设置了一个最长等待时间,如果在规定时间内网页加载完成,则执行 下一步,否则一直等到时间结束,然后执行下一步操作

from selenium import webdriver

fox = webdriver.Firefox()

隐式等待5S

fox.implicitly_wait(5)

fox.get(‘http://www.baidu.com’)

退出网址

fox.quit()

隐式等待5S,这里的例子比较简单,可能你看到的就是刚刚打开就自动退出。

缺点:

1. 使用隐式等待,程序会一直等待整个页面加载完成,才会执行下一步操作;但有时候页面想 要的元素早已经加载完成了,但是因为网页上个别元素还没有加载完成,仍要等到页面全部 完成才能执行下一步,使用也不是很灵活。

2. 在等待时间内页面没有加载完成,时间一到也会进入下一步操作;这种情况可能出现要定位 的元素没有出现,从而报元素无法找到的错误。

优点:

1. 隐性等待对整个driver的周期都起作用,每一次操作都会调用隐式等待,所以只要设置一次 即可

显示等待


程序每隔X秒看一眼,如果条件成立了,则执行下一步,否则继续等待,直到超 过设置的最长时间,然后抛出TimeoutException异常

显示等待一般性结合until来使用,until结合匿名函数lambda来使用,有些人就会问为什么要这样呢,因为显示等待搭配起来可以做更多的工作 ,相对于其他两种等待方式,显示等待可以做的工作超乎你的想象。甚至可以直接作为断言来使用。

from selenium import webdriver

from selenium.webdriver.support.wait import WebDriverWait

fox = webdriver.Firefox()

fox.get(‘https://baidu.com’)

fox.find_element_by_id(‘kw’).send_keys(‘python’)

fox.find_element_by_id(‘su’).click()

ele = ‘/html/body/div[1]/div[4]/div[1]/div[3]/div[3]/h3/a’

驱动,最大等待时间,检测时间间隔,超时后异常信息

wait = WebDriverWait(fox,10,0.5)

判断一个元素是否在存在界面上,message表示若定位不到这个元素啧给出提示信息

l = wait.until(lambda x:x.find_element_by_xpath(ele).is_displayed(),message = ‘无此定位’)

print(l)

.is_displayed() # 元素是否显示,返回True

.is_selected() # 元素是否被选中,返回False

.is_enabled() # 元素是否可用,返回True

退出网址

fox.quit()

这里的message作用就是,当你元素无法定位的时候控制台就会提示你此消息。

缺点:

1. 使用相对比较复杂;

2. 和强制等待类似,每一行等待只执行一次,如果要进行多个元素的等待,则需要多次写入 优点:

1. 等待判断准确,不会浪费多余的等待时间,在用例中使用,可以提高执行效率。

三种等待时间就介绍完了,等待时间是可以互相通用的,隐式等待过程中,你可以加入强制等待,在写项目的过程中,你可以定义一个隐式等待,必要的时候给定强制等待,用显示等待来做一个断言。用多了就知道哪个地方该用什么样的等待时间了。

EC模块

====

EC全名expected_conditions,因为名字太长,很多人都直接将其简写,所以导入包的过程中改名为EC了 。

简介:

expected_conditions是Selenium的一个模块,主要用于对页面元素的加载进行判断,包括元素是否 存在,可点击等等。

Expected Conditions的使用场景一版有两种:

1. 直接在断言中使用

2. 与WebDriverWait配合使用,显示等待页面上元素出现或者消失

写法

1、EC.方法(参数)(driver) ,包含True,不包含False

2、EC.方法(参数).__call__(driver),包含True,不包含False

from selenium import webdriver

from selenium.webdriver.support import expected_conditions as EC

fox = webdriver.Firefox()

fox.get(‘https://www.baidu.com’)

判断标题是否等于百度一下

see = EC.title_is(‘百度一下,你就知道’)(fox)

print(see)

see1 = EC.title_is(‘百度一下,你就知道’).call(fox)

print(see1)

判断标题是否包含百度一下

see2 = EC.title_contains(‘百度一下’).call(fox)

print(see2)

判断元素是否存在(元素定位方式,属性值)

baidu = (‘id’,‘su’)

res = EC.presence_of_element_located(baidu)(fox)

print(res)

搭配显示等待扩展


这里扩张,多增加一点内容,元素定位方式By.,这个定位方式与前面的find_element_by_系列差别无几,这个方式更适合封装的时候使用,看下面的例子。

from selenium import webdriver

from selenium.webdriver.common.by import By

from selenium.webdriver.support import expected_conditions as EC

from selenium.webdriver.support.wait import WebDriverWait

搭配显示等待

se = webdriver.Firefox()

se.get(‘https://www.baidu.com’)

#判断元素是否存在

bd_bth = (By.ID,‘kw’)

ele1 = EC.presence_of_element_located(bd_bth)(se)

ele1.send_keys(‘python’)

#判断元素是否存在

bd_bth1 = (By.ID,‘su’)

ele2 = EC.presence_of_element_located(bd_bth1)(se)

ele2.click()

res_link = (By.XPATH,‘/html/body/div[1]/div[3]/div[1]/div[3]/div[1]/h3/a’)

结合until方法使用,EC调用类不需要调用se

res1 = WebDriverWait(se,10).until(EC.presence_of_element_located(res_link),message=‘元素不存在’)

res1.click()

fox.quit()

WebDriverWait(se,10),默认间隔等待时间是0.5S,所以可以不写,看了上面的例子,是不是对元素定位有了一个不错的认知,这样的方式要是觉得简洁你也可以这么写,定位方式就这些,By系列:By.ID,By.XPATH,By.NAME…但凡有的By都可以.上它,写法就如上述例子。

无头模式

====

听这名字是不是觉得不可思议,但是告诉你,无头模式就是不打开浏览器的情况下,让代码照常的运行。

声明火狐配置对象

fox = webdriver.FirefoxOptions()

无头模式1

fox.set_headless()

无头模式2,True为无头,False为有头模式

fox.headless = True

无头模式3,headless为无头,head为有头

fox.add_argument(argument=‘headless’)

实例化火狐浏览器

fx = webdriver.Firefox(firefox_options = fox)

fx.get(‘http://www.baidu.com’)

if fx.title==‘百度一下,你就知道’:

print(‘打开成功’)

else:

print(‘打开失败’)

这里给出了三种无头模式,喜欢哪种就用哪种吧,无头模式还没比较方便的,至少我认为方便不少。特殊时候特殊使用。

窗口切换

====

这个操作还是十分实用的,可以帮助你定位很多的页面,比如知乎登录界面,QQ网页邮箱等。。。先来了解一下其他的操作吧。慢慢来,切记,跟着码代码。

设置窗口大小


先打开百度界面,然后进行一些列的设置操作。

from selenium import webdriver

fx = webdriver.Firefox()

隐式等待10秒

fx.implicitly_wait(10)

fx.get(‘http://www.baidu.com’)

设置窗口指定大小

fx.set_window_size(900,600)

窗口最大化

fx.set_minmize_window()

最小化

fx.set_maxmize_window()

三种设置窗口都可以自己跑起来看看,这里我用了隐式等待,隐式等待在调试过程中还是比较方便的。

多窗口切换


有些页面的链接打开后,会重新打开一个窗口,对于这种情况,想在新页面上操作,就 得先切换窗口了。

在web应用中,每一个窗口都有一个对应的唯一句柄来进行标识,如果我们切换窗口, 则只需要获取新窗口的句柄,然后切换句柄即可。

每一个窗口的唯一标识,每个窗口的句柄都不一样

1. 获取当前句柄 :driver.current_window_handle

2. 获取所有句柄:driver.window_handles

3. 切换句柄:driver.switch_to_window(句柄号)

我们看代码:

from time import sleep

from selenium import webdriver

# 实例化火狐浏览器

fox = webdriver.Firefox()

隐式等待5秒

fox.implicitly_wait(5)

fox.get(‘https://baidu.com’)

获取窗口句柄号

bai_1 = fox.current_window_handle

print(bai_1)

点击学术连接

fox.find_element_by_link_text(‘学术’).click()

bai_2 = fox.current_window_handle

print(bai_2)

获取所有窗口句柄号

all_h = fox.window_handles

print(all_h)

切换窗口,列表取值1,python舍弃的方法

fx.switch_to_window(all_h[-1])

切换窗口,列表取值2,python推荐的方法

fox.switch_to.window(all_h[-1])

点击文本操作

fox.find_element_by_class_name(‘new_index_icon_scholar’).click()

sleep(2)

切回百度窗口

fox.switch_to.window(bai_1)

搜索其他内容

fox.find_element_by_id(‘kw’).send_keys(‘python’)

fox.find_element_by_id(‘su’).click()

fox.quit()

这个例子,获取单个窗口号是可以省略的,因为后面我写了一个获取全部的窗口号,主要是为做了解,但也要记住了。

iframe

这个就比较有意思了,事关切换到登录界面进行登录操作!

肝万字,带你走进selenium,10天从0-1硬核知识(上),程序员,selenium,测试工具

如果学了上述之后,你觉的你可以了,那你就很膨胀,飘了?

有iframe的不做特殊切换操作是定位不了的,不信   你可以去试试。定位这个特殊的元素,与之前的操作也近乎相似,看这个163邮箱的例子。

iframed定位案例

fx = webdriver.Firefox()

fx.implicitly_wait(10)

fx.get(‘https://mail.163.com’)

定位到iframe,列表取值第一个iframe

if_rame = fx.find_elements_by_tag_name(‘iframe’)[0]

切换到iframe中,第一种方法

fx.switch_to_frame(if_rame)

第二种

fx.switch_to.frame(if_rame)

用户名

fx.find_element_by_name(‘email’).send_keys(‘1235646@163.com’)

密码

fx.find_element_by_name(‘password’).send_keys(‘6541566’)

点击登录

fx.find_element_by_id(‘dologin’).click()

切出iframe,点击企业邮箱

fx.switch_to_default_content()

fx.find_element_by_link_text(‘企业邮箱’).click()

fx.quit()

肝万字,带你走进selenium,10天从0-1硬核知识(上),程序员,selenium,测试工具

这个画横线的是过期语法,不过不影响使用。学会了这个,赶紧去试试QQ空间吧,自己写一个出来,https://qzone.qq.com/地址给到给到你们啦。

弹窗处理

Alter:一般只有确认按钮

confirm:一般有确认取消按钮

prompt:一般有文字输入款,加上确认取消按钮

操作 方法:

1. switch_to_alert() 首先要切换到 alert 弹出框上,才能做确定、取消等这些操作

2. accept() :点击"确认"

3. dismiss() :点击"取消"

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Python工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Python开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

肝万字,带你走进selenium,10天从0-1硬核知识(上),程序员,selenium,测试工具

肝万字,带你走进selenium,10天从0-1硬核知识(上),程序员,selenium,测试工具

肝万字,带你走进selenium,10天从0-1硬核知识(上),程序员,selenium,测试工具

肝万字,带你走进selenium,10天从0-1硬核知识(上),程序员,selenium,测试工具

肝万字,带你走进selenium,10天从0-1硬核知识(上),程序员,selenium,测试工具

肝万字,带你走进selenium,10天从0-1硬核知识(上),程序员,selenium,测试工具

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以扫码获取!!!(备注Python)文章来源地址https://www.toymoban.com/news/detail-853686.html

41566’)

点击登录

fx.find_element_by_id(‘dologin’).click()

切出iframe,点击企业邮箱

fx.switch_to_default_content()

fx.find_element_by_link_text(‘企业邮箱’).click()

fx.quit()

肝万字,带你走进selenium,10天从0-1硬核知识(上),程序员,selenium,测试工具

这个画横线的是过期语法,不过不影响使用。学会了这个,赶紧去试试QQ空间吧,自己写一个出来,https://qzone.qq.com/地址给到给到你们啦。

弹窗处理

Alter:一般只有确认按钮

confirm:一般有确认取消按钮

prompt:一般有文字输入款,加上确认取消按钮

操作 方法:

1. switch_to_alert() 首先要切换到 alert 弹出框上,才能做确定、取消等这些操作

2. accept() :点击"确认"

3. dismiss() :点击"取消"

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Python工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Python开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

[外链图片转存中…(img-c9e6CllT-1712835194513)]

[外链图片转存中…(img-2hCYpIMB-1712835194514)]

肝万字,带你走进selenium,10天从0-1硬核知识(上),程序员,selenium,测试工具

肝万字,带你走进selenium,10天从0-1硬核知识(上),程序员,selenium,测试工具

肝万字,带你走进selenium,10天从0-1硬核知识(上),程序员,selenium,测试工具

肝万字,带你走进selenium,10天从0-1硬核知识(上),程序员,selenium,测试工具

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以扫码获取!!!(备注Python)

肝万字,带你走进selenium,10天从0-1硬核知识(上),程序员,selenium,测试工具

到了这里,关于肝万字,带你走进selenium,10天从0-1硬核知识(上)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 万字长文硬核AQS源码分析

    阅读本文前,需要储备的知识点如下,点击链接直接跳转。 java线程详解 Java不能操作内存?Unsafe了解一下 一文读懂LockSupport AQS即 AbstractQueuedSynchronizer 的简称,翻译过来就是抽象队列同步器的意思,由Doug Lea大神开发的。说他抽象是因为它提供的是一个基于队列的同步器框架

    2024年02月11日
    浏览(52)
  • 2万字硬核spark源码精讲手册

    大家好,我是老兵。 本期为大家带来spark源码精讲系列,我将结合自身的理解深入浅出的剖析spark内核。全文内容很肝,希望能够给大家提供帮助。 本文整体基于Spark2.4.1代码讲解,首先需要准备编译环境。 1)编译环境 1)scala2.11+ jdk1.8+ maven3.5+ Git2.0 + Spark2.4.1 2)windows环境(

    2023年04月24日
    浏览(47)
  • 【Java基础教程】(三十)Java新特性篇 · 第十讲: Stream流——释放流式编程的效率与优雅,狂肝万字只为透彻讲清 Stream流!~

    Java的Stream流是在Java 8中引入的一种用于处理集合数据的功能强大且易于使用的工具,旨在简化集合框架的操作。它的设计目的是为了提供一种更简洁、更灵活和更可读的方式来处理集合数据。 在之前,我们通常使用迭代器或循环来遍历和操作集合元素,这种方式容易出错且

    2024年02月16日
    浏览(37)
  • 带你走进灵动岛

    iOS最近几年新特性 iOS14 视频画中画 AppLibrary 桌面小组件 照片隐私加强 应用限免 智能折叠 全新siri悬浮显示 iOS15 FaceTime支持屏幕共享 信息和新增拟我表情 推出专注模式 通知重新设计,图标变得更大 地图公共交通路线置顶,增加时间显示 识别图片上文字信息 支持照片信息和

    2024年02月05日
    浏览(44)
  • 带你走进Harmony OS 开发

    HUAWEI HarmonyOS 鸿蒙系统(鸿蒙 OS)是一款“面向未来”、面向全场景(移动办公、运动健康、社交通信、媒体娱乐等)的分布式操作系统。在传统的单设备系统能力的基础上,HarmonyOS提出了基于同一套系统能力、适配多种终端形态的分布式理念,能够支持多种终端设备。 Har

    2024年02月04日
    浏览(45)
  • vLive带你走进虚拟直播世界

    虚拟直播是什么? 虚拟直播是基于5G+实时渲染技术,在绿幕环境下拍摄画面,通过实时抠像、渲染与合成,再推流到直播平台的一种直播技术。尽管这种技术早已被影视工业所采用,但在全民化进程中却是困难重重,面临着克服相关技术难题。该技术的应用需要具备专业导演

    2023年04月20日
    浏览(43)
  • APISpace 带你一起走进西湖美景

    俗话说:“上有天堂,下有苏杭”。 “欲把西湖比西子,浓妆艳抹总相宜” 今天我就带大家走进杭州的西湖美景。自古以来,文人歌者面对西湖美景留下千古绝句,还以西湖为背景书写了一段段动人的爱情传说。 天生自带浪漫色彩的西湖如何画?是苏堤,是断桥,是岸边细

    2024年02月09日
    浏览(38)
  • 详解C++类&对象(上篇),带你走进C++

    目录 一,面向对象面向过程的认识(简单了解即可,逐步认识) 二, 类 2.1 类的引入  2.2 类的定义 1. struct  2. class  类的两种定义方式: 2.3 封装类的访问限定符  1. 封装概念 2. 类的访问限定符  2. 4 类的作用域 2. 5 类对象模型 1. 计算类大小 2. 类对象的存储方式 2.6  结构体

    2024年02月05日
    浏览(39)
  • 带你走进JAVA的世界|用心感受JAVA

    作者主页:paper jie的博客 本文作者:大家好,我是paper jie,感谢你阅读本文,欢迎一建三连哦。 本文录入于《JAVASE语法系列》专栏,本专栏是针对于大学生,编程小白精心打造的。笔者用重金(时间和精力)打造,将javaSE基础知识一网打尽,希望可以帮到读者们哦。 其他专栏

    2024年02月15日
    浏览(43)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包