最新selenium+python面试题目总结(2),2024年最新社招面试心得

文末有福利领取哦~

👉一、Python所有方向的学习路线

Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。img

👉二、Python必备开发工具

img
👉三、Python视频合集

观看零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。
img

👉 四、实战案例

光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。(文末领读者福利)
img

👉五、Python练习题

检查学习结果。
img

👉六、面试资料

我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
img

img

👉因篇幅有限,仅展示部分资料,这份完整版的Python全套学习资料已经上传

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

特点:

·支持录制回放

·多种方式对页面元素进行定位并操作

·能够及进行debug和设置断点

·能够把测试脚本保存成html/ruby或者其他语言

·支持user-extensions.js形式的用户扩展

·能够进行页面的断言

  1. Selenium IDE: 是firefox的插件,可以录制/回放/测试脚本

  2. Selenium RC:支持程序语言(java/C#/python/ruby)编写测试用例; selenium和其他测试框架集成,比如java环境下将selenium和Junit集成,利用selenium来书写测试用例,用Junit来实现测试用例的自动化运行。

  3. Selenium Core:是selenium的核心,是有js和html文件组成,它是selenium IDE和selenium RC的核心引擎。

  4. Selenium Grid:是selenium的扩展,可以将一批selenium脚本分配到不同的测试机上同步运行。即selenium grid可以在不同的主机上建立主节点(hub)和分支节点(node), 可以使主节点上的测试用例在不同的分支节点上运行。对于不同的节点来说,可以搭建不同的测试环境(操作系统/浏览器)。

3.如何提高自动化脚本稳定性

找原因

1)网速原因,增加时间等待

2)函数原因,尽量少使用容易冲突的函数

3)配置testNG实现多线程,在编写测试用例的时候,一定要实现松耦合,在服务器允许的情况下尽量设置多线程运行,提高执行速度。

4.高质量自动化脚本特点

业务和代码分离,封装型好。

自动化用例耦合性低,独立性强,易于扩展维护

5.自动化测试缺陷

不稳定

可靠性不强

不易维护

成本与收益

6.自动化用例的执行策略

根据自动化执行的目的来决定

(1)自动化测试用例执行用来监控,可以设置用例定时执行;

(2)用于回归测试,可以把测试用例设置成触发式执行;

(3)不需要经常执行的测试用例,可以由人工执行。

7. 提高selenium脚本的执行速度方式

(1)减少操作步骤,减少不必要的操作;

(2)中断页面加载,如果页面加载内容过多并且加载的内容不影响我们测试,可以设置超时时间,中断页面加载;

(3)设置等待时间的时候,可以sleep()固定的时间,检测到元素出现后中断等待也可以提高速度;

(4) 配置testNG实现多线程,在编写测试用例的时候,一定要实现松耦合,在服务器允许的情况下尽量设置多线程运行,提高执行速度。

8.元素定位

  1. Id定位

find_element_by_id(‘kw’)   //通过id属性定位

  1. Name定位

find_element_by_name(‘wd’)    //通过名字进行定位,名字一般不唯一,一般不能通过其定位

  1. ClassName定位

find_element_by_class_name(‘cn’)   //通过类名进行定位

  1. TagName定位

find_element_by_tag_name(‘input’)  //标签,一般用于一类元素的定位

  1. LinkText定位

find_element_by_link_text(‘新闻’)  //文本链接定位

  1. PartialLinkText定位

find_element_by_partial_link_text(‘一个很长的’) //文本链接的部分文字

  1. 绝对路径定位find_element_by_xpath(‘/html/body/div/div[2]/form/span/input[2]’) //绝对地址定位,利用层级定位

find_element_by_xpath(‘//input[@name=’n’ and id=’kw’]’) //当前页面某个目录下 name为n,id为kw的input标签,利用元素属性进行定位

find_element_by_xpath(‘//*[@id=kw]’) //其中*表示任何属性,表示id为kw的任何属性的元素

find_element_by_xpath(‘//span[@class=’c’]/input’) //层级和属性结合进行定位

find_element_by_xpath(‘//a[contains(href , ’test’)]’)

  1. 相对路径定位

相对路径定位一般比绝对路径定位快。

find_element_by_css_selector(‘.class1’) // 类名定位 .class

find_element_by_css_selector(‘#id’) //id定位 #id

find_element_by_css_selector(‘input’) // 标签名定位

find_element_by_css_selector(‘[autocomplete=off]’) //属性定位

find_element_by_css_selector(‘span>input’) //标签名为span的input子元素

✎✎✎第二小节

  1. 定位一组元素

Checkboxes = find_elements_by_tag_name(‘checkbox’)

for checkbox in Checkboxes:

checkbox.click()  # 通过for循环全选所有的checkbox

Checkboxes.pop().click()  #取消勾选一些checkbox,pop(-1)=pop()表示一组元素的最后一个;pop(0)      表示一组元素的第一个,pop(1)表示一组元素的第二个,以此类推

  1. 父子/兄弟/相邻节点的定位

·父->子

Find_element_by_id(‘parent’).find_element_by_tag_name(‘input’) 串联寻找

Find_element_by_xpath(‘//input/div[@name=’n’]/span/input[1]’)  xpath的层级

Find_element_by_css_selector(‘div#b>input’) css selector的父子关系·子->父

Find_element_by_xpath(‘//div[@id=’c’]/…/…’) 其中//div[@id=’c’]的父亲的父亲

·哥哥->弟弟

Find_element_by_xpath(‘//div[@id=’c’’/…/div[1]) 找到弟弟后找父亲然后找哥哥

Find_element_by_css_selector(‘div#d+div’) 表示id=d的div后面紧跟着的div

Find_element_by_css_selector(‘div#d~div’) 表示id=d的div后面同一级所有div

  1. 二次定位

Element1 = driver.find_element_by_id(‘ID1’)

Element2 = Element1.find_element_by_id(‘ID2’)

  1. display: none 和hidden的区别

共同点:把网页中的某个元素隐藏起来;他们在selenium中都是定位不到的。

区别:display:none不为隐藏的对象保留其物理空间,该对象在这个页面上彻底

失,看不到/摸不到;hidden使对象在网页上不可见,但该对象在网页中依然占有空间,看不到/摸得到。

备注:isElementPresent()来判断元素是否存在。

9.常见控件使用

  1. link/button:

element.click()

注:ajax不能使用clickAndWait()函数,因为cickAndWait函数会在click之后等待页面重新加载完成,而ajax是部分刷新,所以这个页面不能重新加载完成。

  1. Textbox:

element.send_keys(‘test’)

  1. Upload

Driver.find_element_by_id(‘id’).send_keys(‘D\test.txt’)

  1. Mouse Event:

e1=driver.find_element_by_id(‘kw’)

ActionChains(driver).double_click()/.context_click()/.drag_and_drop()/.move_to_eleme        nt()/.perform()   # 双击/右击/拖动/悬停/执行actionChains中的行为

5) Dropdown:

·标签的下拉菜单

from selenium.webdriver.support.ui import Select

Select(driver.find_element_by_id(‘gender’)).select_by_index(1)

Select(driver.find_element_by_id(‘gender’)).select_by_value(“2”)

Select(driver.find_element_by_id(‘gender’)).select_by_visible_text(“Male”)

·非标签的下拉菜单

Dropdown1 = driver.find_element_by_id(‘id’) #先定位到dropdown

Dropdown1.find_element_by_id(“li2_input_2”) #再定位到dropdown中的值

6) Alert:

在这里插入图片描述

感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的:

① 2000多本Python电子书(主流和经典的书籍应该都有了)

② Python标准库资料(最全中文版)

③ 项目源码(四五十个有趣且经典的练手项目及源码)

④ Python基础入门、爬虫、web开发、大数据分析方面的视频(适合小白学习)

⑤ Python学习路线图(告别不入流的学习)

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值