网站广告联盟平台,绿色在线网站,阀门公司网站建设,短视频seo关键词一、编程语法题
1 、 python 有哪些数据类型 python 数据类型有很多#xff0c;基本数据类型有整型#xff08;数字#xff09;、字符串、元组、列表、字典和布尔类型等
2 、怎么将两个字典合并
调用字典的 update 方法#xff0c;合并 2 个字典。
3 、 json.l python …一、编程语法题
1 、 python 有哪些数据类型 python 数据类型有很多基本数据类型有整型数字、字符串、元组、列表、字典和布尔类型等
2 、怎么将两个字典合并
调用字典的 update 方法合并 2 个字典。
3 、 json.l python 如何将 json 写到文件里
loads 是将字符串转化为字典
json.load()是将文件打开从字符串转换成数据类型
json.dumps ( 是将字典转化为字符串
json.dump()是将数据类型转换成字符串并存储在文件中
4 、 init 和 new 区别
__new__是在实例创建之前被调用的因为它的任务就是创建实例然后返回该 实例对象是个静态方法。
__init__是当实例对象创建完成后被调用的然后设置对象属性的一些初始值通常用在初始化一个类实例的时候。是一个实例方法。
5 、什么是可变、不可变类型
可变数据类型列表 list 和字典 dict
不可变数据类型整型 int、浮点型 float、字符串型 string 和元组 tuple
6 、 mysql 注入点用工具对目标站直接写入一句话需要哪些条件
mysql 写入一句话需要具备
1.secure-file-priv‘’即my.ini 文件打开找到 secure-file-priv 参数改空
2.当前用户具备 root 权限
3.已获取到应用程序的绝对路径且目录可以进行文件写入操作。
7 、 python 深浅拷贝的区别
对于不可变数据来说深浅拷贝的结果一致会重新创一个数据的副本。浅拷贝对于 可变类型来说只会拷贝其元素的引用。
深拷贝对于可变元素来说会递归的整个重新创建一个原数据的副本。
8 、 python 为什么使用 *args 和 **kwargs
如果我们不确定要往函数中传入多少个参数或者我们想往函数中以列表和元组 的形式传参数时那就使用args如果我们不知道要往函数中传入多少个关 键词参数或者想传入字典的值作为关键词参数时那就要使用**kwargs。args 和 kwargs 这两个标识符是约定俗成的用法你当然还可以用bob 和**billy 但是这样就不太专业。
9 、重写和重载有什么区别
重写用在类的继承当中。子类对父类的同名方法进行重写。在子类同名方法 内部如果要延用父类的方法可以使用 super 调用。
重载用在类当中对于同一个方法名支持不同类型的参数支持不同数量的 参数。由于 python 的函数本身就对参数不作类型限定也有*args 和**kwargs 支持不定长度参数。
10 、 python 实现 get 数据库的表你是怎么实现的
python 当中对于不同数据库都有不同的第三库来实现连接和数据库操作。
比较熟悉的是对 mysql 的操作。使用的是 pymysql 这个第三方库。第一步是建立 数 据 库 连 接 第 二 步 调 用 execute 方 法 执 行 sql 语 句 第 三 步 使 用 fetchone,fetchall,fetchmany 去获取不同条数的结果。
11 、对象 ( 实例 ) 方法类方法静态方法的定义有何不同分别适用于什么场 景
python 中类中定义的普通函数就是对象方法对象方法中的第一个形参一般 会定义为self表示调用的对象本身当对象调用对象方法时会被隐式的传递 给这个形参。所以当函数需要用到对象或对象的属性时一般会将其定义为对象方 法。
类方法定义时需要使用装饰器classmethod进行装饰类方法中的第一个形 参一般会定义为cls表示类本身。当对象调用或类调用类方法时类会被隐 式的传递给这个形参。所以当函数需要用到类或者类的属性时一般会将其定义为 类方法。
静态方法定义时需要使用装饰器staticmethod进行装饰其他与普通函数没 有区别。一般会将一些与对象和类无关的工具函数定义为静态方法方便调用。
12 、 SQL 连表查询去重查询查询重复的数据
两表查询SELECT 字段 1,字段 2,字段 3,…… FROM 表名 1 INNER JOIN 表名 2
ON 关联条件
去重查询SELECT distinct ...;
查询重复的数据select 列名 from 表名 group by 列名 having count(列名) 1;13 、 python 的单例模式
单例模式是确保类有且只有一个对象被创建为唯一对象提供访问点令其可被全局访问控制共享资源的并行访问
具体实现方式可以通过模块导入、装饰器、控制 __new__方法 等等。
14 、什么是 PEP 8
EP 8 代表 Python Enhancement Proposal它可以定义为帮助我们提供有关如何编写 Python 代码的指南的文档。它基本上是一组规则指定如何格式化
Python 代码获得最大的可读性。它由 Guido van Rossum、Barry Warsaw 和Nick Coghlan 于 2001 年编写
15 、 PO 模式的封装原则有哪一些
公共方法表示页面提供的服务。比如把登录封装成 login 方法搜索操作封装成 search 方法注册操作封装成 register 方法。
尽量不要暴露页面的内部比如页面的 HTML, 页面的上下结构
一般不做断言做到页面逻辑和测试逻辑的分离。
方法返回 self 或者其他 PageObjects也可以是元素属性等。
不需要封装整个页面行为用到什么逻辑封装什么逻辑
同一操作如果出现不同结果可以用不同的方法表示。比如登录成功有跳转登录失败报错登录未授权
二、编码题
1 、幂的递归计算 x 的 n 次方如3 的 4 次方 为 333*381
# 递归的方式
def mi(x, n):
if n 0:
return 1
else:
return x*mi(x, n-1)
print(mi(3, 4))
非递归的方式
def mix(x,n):
result 1
for count in range(n):
result * x
return result
print(mi(3,4))2 、统计列表list 中每个元素出现的次数
# 统计列表list中每个元素出现的次数
lista [1, 2, 3, 4, 12, 22, 15, 44, 3, 4, 4, 4, 7, 7, 44, 77, 100]
new_dict {}
for item in lista:
if item not in new_dict.keys():
new_dict[item] lista.count(item)
print(new_dict)3 、 [‘abc13’,‘abv89’] 这种列表打印最大长度的共同的前缀列表元素个数不确定
def test_str(iterable):
return_str
for i in zip(*iterable):
if len(set(i))1:
return_str i[0]
else:
break
print(return_str)
return return_str4 、对 list 去重并找出列表 list 中的重复元素
from collections import Counter #引入 Counter
a [1, 2, 3, 3, 4, 4]
b dict(Counter(a))
print(b)
print ([key for key,value in b.items() if value 1]) #只展示重复元素
print ({key:value for key,value in b.items() if value 1}) #展现重复
元素和重复次数5 、已知一个队列 [1, 3, 6, 9, 7, 3, 4, 6] 按从小到大排序 按从大大小排序 去除重复数字
a [1, 3, 6, 9, 7, 3, 4, 6]
# 1.sort 排序正序
a.sort()
print(a)
# 2.sort 倒序
a.sort(reverseTrue)
print(a)
# 3.去重
b list(set(a))
print(b)6 、任选语言完成双向冒泡排序算法程序[8,6,4,3,9,1,2,5,7] 升序
def cocktail_sort(arr):n len(arr)start 0end n - 1swapped Truewhile swapped:# 正向冒泡找到最大元素放到后面swapped Falsefor i in range(start, end):if arr[i] arr[i 1]:arr[i], arr[i 1] arr[i 1], arr[i]swapped True# 如果没有元素进行交换则排序完成if not swapped:break# 在反向冒泡之前重新标记 swapped 为 Falseswapped Falseend - 1# 反向冒泡找到最小元素放到前面for i in range(end - 1, start - 1, -1):if arr[i] arr[i 1]:arr[i], arr[i 1] arr[i 1], arr[i]swapped Truestart 1return arr# 测试排序算法
arr [8, 6, 4, 3, 9, 1, 2, 5, 7]
sorted_arr cocktail_sort(arr)
print(sorted_arr)三、自动化基础能力评估
1 、 python 列表和字典的区别列表和元组的区别
列表是有序的字典是无序的。列表通过索引获取、字典通过 key 获取。
列表是可变的可以修改、添加、删除其中的元素但是元组是不可变的不能修改、添加、删除其中的元素。
对于一个元素的元组必须要在元素后加逗号而列表不需要。
2 、 Python 用到的库
单元测试框架unittest pytest 操作 mysql 数据库pymysql http 请求库requests web 自动化selenium 处理日志:logging json 数据提取和 json 文件读写:jsonjsonpath pyyaml:yaml 文件读写
3 、 unittest 和 pytest 区别
pytest 是第三方库基于 unittest 的扩展框架比 unittest 更简洁高效 pytest 有丰富的插件系统 pytest 的夹具使用更加灵活 pytest 可以很方便的过滤用例
4 、 python 当中如何操作数据库 ?
python 不同的数据库都有对应的第三方库。比如 mysql 数据库有 pymysql库oracle 数据库有 cx_Oracle 安装成功第三方库后代码中将包导进来 ·接下来就是连接数据库提供数据库的服务器地址、端口号、访问的用户名和密码、数据库名称通过调用对应的方法去连接 连接成功之后调用执行 sql 语句的方法去操作数据库 操作完成之后释放数据库连接
5 、 jmeter 或 postman 实现多接口关联测试 ? 怎么做关联 ?
6 、接口自动化的断言怎么做
7 、如果需要用自动化测删除接口断言怎么做
8 、做自动化的过程中如何处理验证码
让开发屏蔽验证码邀请开发处理在测试环境预发和正式环境恢复 让开发设置一个万能验证码使用复杂的其他人无法猜到的验证码 基于图像识别破解验证码
9 、自动化测试用例如何编写
自动化测试本质是测试是用自动化手段替代部分手工测试。 自动化测试用例源自功能测试用例都应包含前置/后置步骤断言。 自动化用例设计原则与功能用例一致。 自动化用例需要自行解决环境依赖问题。比如手工测试时遇到前置条件不满足手工去准备前置条件再测试。 自动化用例断言要明确将手工测试看到的期望效果转成代码。 自动化用例需要考虑重复执行不受影响。 考虑好以上 5 点使用工具或者代码的测试框架编写即可。
10 、 pytest 的前置实现有哪几种方式
11 、 Appium 都有哪些启动方式
12 、 web ui 自动化中显式等待、隐式等待有什么区别
相同点都是智能等待在一定时间范围内不断查找元素一旦找到立刻执行后续代码没找到就会一直查找到超时为止
不同点
显式等待显示等待是单独针对某个元素设置一个等待时间设置一个查询间隔时间在等待时间内会按照设置的间隔时间对该元素进行查找超过设置的等待时间尚未出现则抛异常显示等待必须在每个需要等待的元素前面进行声明
隐式等待隐式等待是全局的是针对所有元素设置一个等待时间在设置的等待时间内程序会不停检测页面元素是否全部加载完成加载完成则继续向下超过设置的等待时间尚未出现则抛异常隐式等待只需要声明一次声明之后对整个 drvier 的生命周期都有效不用重复声明程序会一直等待整个页面加载完成
13、 有没有遇到元素定位不到情况如何处理的
页面加载元素过慢添加等待时间
页面有 frame 框架页需要先跳转入 frame 框架再定位
可能该元素是动态元素定位方式要优化可以使用部分元素定位或通过父节点或兄弟节点定位。
可能识别了元素但是不能操作比如元素不可用不可写等。需要使用js 先把前置的操作完成
元素定位的表达式写错了。
14 、请尽可能多的列出自动化的元素定位方式以及你最喜欢的定位方式
web 自动化的定位方式
1、通过 idfind_element_by_id
2、通过 name 属性find_element_by_name
3、通过 class 属性find_element_by_name
4、通过标签名find_element_by_tag_name
5、通过文本定位链接标签find_element_by_link_text
6、通过文本部分匹配定位链接标签find_element_by_partial_link_text
7、通过 xpath 定位find_element_by_xpath
8、css 选择器定位find_element_by_css_selector
最常用的id,xpath 和 css 这三种15 、如果同一个浏览器打开两个窗口要用 selenium 里面哪个指令进行切换
1、窗口切换 2、iframe 切换 3、alert 切换
16 、 App 自动化有做过吗知道用到哪些技术框架吗
做过app 自动化主要使用的开源框架 appium结合测试框架 pytest还有 PO设计思想共同搭建了 app 自动化测试框架。
17 、 ui 自动化出现的异常以及出现这些异常后你是如何处理的
元素定位失败异常处理方式为检查元素定位表达式添加等待
定位超时异常检查定位方式检查是否有 iframe
元素无法交互检查是否定位到正确元素。
18 、什么是 PO 模式什么是 page factory
PO 模式是 page object model 的缩写顾名思义 是一种设计模式把每个页面当成一个页面对象页面层写定位元素方法和页面操作方法,实现脚本的page 和真实的网站页面 Map 起来一对应起来PO 模式业务代码和测试代码被分开降低耦合性维护成本低减少代码冗余
19 、简述 selenium 的原理
selenium 涉及到三个组件的通讯分别是 浏览器 webdriver client client 负责通过对应的编程语言函数发送请求给 webdriver client 其实并不知道浏览器是怎么工作的但是 driver 知道在 selenium 启动以后driver 其实充当了服务器的角色跟 client 和浏览器通信client根据 webdriver 协议发送请求给 driverdriver 解析请求并在浏览器上执行相应的操作并把执行结果返回给 client。这就是 selenium 工作的大致原理。
20 、 UI 自动化测试用例在运行过程中经常会出现不稳定的情况也就是说这次
可以通过下次就没有办法通过了如何去提升用例的稳定性 界面上无法预测的弹框。页面上经常会根据用户行为推送或者弹出动态的信息比如版本更新消息通知推荐产品等等当这些弹框出现以后原来的页面元素会被遮挡无法被定位此时可能会造成自动化测试脚本运行错误。 页面元素的动态变化主要有两方面的变化第一方面前端需求经常发生变化导致前端代码频繁修改当前端页面变化以后可能会造成之前的元素无法被定位第二方面页面可能会根据用户的状态和等级展示不同的页面或者是这一次访问的数据和下一次会不同。 随机的页面延迟造成控件识别失败受限于网络环境和设备状态自动化代码每次运行时可能会产生随机的超时处理。 测试数据变更。ui 测试每个用例的测试步骤会有很大的区别他们不能共享同一套代码逻辑当测试数据变更时如果不能及时更新自动化代码会造成脚本执行出错等问题。
四、自动化项目实战能力评估
1 、介绍一下你的自动化测试框架
我的框架主要根据分层思想设计了几个独立模块
模块一主要存放通用业务代码比如接口访问数据库操作excel 操作等 模块二主要负责用例收集和用例执行生成测试报告。
模块三主要负责存放测试用例数据。通常是使用 excel, yaml, 等通用数据格式。
模块四主要存放测试用例方法和测试逻辑相关代码。这里会调用模块的通用方法。
2 、讲一下在工作中怎么做的自动化测试
a. 根据自动化测试特性整理需求 b. 根据优先级和公司人员状况制定自动化测试计划 c. 制定自动化测试执行方案 d. 自动化测试用例设计或从功能测试用例中挑选适合的用例 e. 自动化脚本的开发 f. 自动化测试执行生成报告
3 、自动化测试框架至少包含哪些核心模块。
基础方法 数据驱动 PO 分层 接口分层 接口数据管理 异常处理 - 工具包 配置 日志收集 测试报告
4 、框架中的接口参数传递怎么做的是否有优化第三库有没有用到方法是什么
框架当中接口参数传递主要涉及 2 部分一是数据生成或者提取二是替换。在框架当中数据从响应结果提取用的 jsonpath提取表达式直接写在 excel 当中提取之后存储到变量类 Data 当中作为它的类属性。
替换时则直接访问 Data 类的类属性将其值拿到并替换。在 excel 中要替换的标志为#value#。因为会存在有多个要替换的值所以用正则表达式来查找到所有要替换的标识然后全部替换。
用到第三方库的话一个是 jsonpath一个是 re
5 、拿到一个项目怎么衡量这个项目做接口自动化还是 UI 自动化
1、不管什么项目都可以做接口自动化
2、偏公司内部人员使用的管理平台无需做 UI 自动化对外用户的可以考虑做 UI 自动化
6 、框架的数据库验证在你 excel 中 check_sql 放的是什么你如何做比对
check_sql 中存放的是一个列表列表的成员是字典字典有 3 个 key,一个是sql 语句第二个是期望结果第三个是 sql 的查询方式(查询总条数/查询值)在收到响应结果以后会遍历 check_sql 中的列表将每一个字典取出来执行sql 语句查询结果 并与期望结果做比较。
7 、自动化测试中测试用例的执行是怎么让他按照你写的用例一条一条执行的 在我的项目接口自动化中我用 pytest 框架。
一个接口的用例我的用例数据是写在 excel 当中在编写时就是按照顺序写的从 excel 读取出来使用数据驱动 方式就是按照 excel 中的顺序
多个接口的用例因为我是一个接口一个 py 测试文件所以我在 py 测试文件命名中用 00-99 数字按顺序编写的。
8.Login 这些用例数据是在哪里取的excel 吗用到什么方法什么第三方库
具体公司的业务业务怎么开展 项目的介绍( 或者简单介绍最熟悉的项目介绍) 主要考察 2 个方面一是表达能力和业务的熟悉度。二是做的项目复杂度如何是否能胜任复杂项目的测试工作。
一般是根据自己的业务来回答。最好是能讲出有挑战性有难度或者复杂的业务场景。面试官不一定听得懂但是他觉得复杂挺难的就可以。
总结
感谢每一个认真阅读我文章的人
作为一位过来人也是希望大家少走一些弯路如果你不想再体验一次学习时找不到资料没人解答问题坚持几天便放弃的感受的话在这里我给大家分享一些自动化测试的学习资源希望能给你前进的路上带来帮助。 软件测试面试文档
我们学习必然是为了找到高薪的工作下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料并且有字节大佬给出了权威的解答刷完这一套面试资料相信大家都能找到满意的工作。 视频文档获取方式 这份文档和视频资料对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库这个仓库也陪伴我走过了最艰难的路程希望也能帮助到你以上均可以分享点下方小卡片即可自行领取。