1.取列表中的最后一个元素
a = [1,2,4,2,11,33,12]
print(a[-1])
2.反转列表中的元素
a = [1,2,4,2,11,33,12]
#反转方法一
a.reverse()
print(a)
#反转方法二
a[::-1]
print(a)
3.str常用方法
a = "abCDef"
a = ['a','b']
a = "#".join(a)
print(a)
a = "abCDef"
#转大小定方法
a.lower()
#是否是以f结束
a.endswith("f")
#是否是以a开头
a.startswith("a")
#格式化字符串
a.format("")
#a的索引,没有找到-1
a.find("a")
#a的索引。没有找到报异常
a.index("a")
#把字符串加#
a.join("#")
#切割字符串
a.split(",")
#去空格
a.strip()
#大写
a.upper()
4.动态参数
# *打包,打包成元组
def star(*args):
print(type(args))
star(1,2,3)
# *解包成单个元素
def star(a,b,c):
print(a,b,c)
a = (1,2,3)
star(*a)
#打包成字典
def star2(**kwargs):
print(type(kwargs))
star2(a=1,b=2,c=3)
#解包成单个元素
def start22(a,b,c):
print(a,b,c)
dic = {"a":"aa","b":"bb","c":"cc"}
start22(**dic)
5.装饰器
#在不改变代码的情况下,还给已有代码增加新功能
def a():
print("a")
def b(fun):
print("b")
fun()
b(a)
def log(fun):
'''
增加了记日志的功能
:param fun:
:return:
'''
def wrapper(*prams,**kwargs):
print("现在执行加法运算")
return fun(*prams,**kwargs)
return wrapper
def add(a,b):
return a+b
#把函数作为变量名传过去。用时再调用。函数名()才是调用
a = log(add)
print(a(1,2))
def log(fun):
'''
增加了记日志的功能。用时再传参数
:param fun:
:return:
'''
def wrapper(*prams,**kwargs):
print("现在执行加法运算")
return fun(*prams,**kwargs)
return wrapper
#加注解更方便调用。不会影响代码的逻辑
@log
def add(a,b):
return a+b
s = add(1,2)
print(s)
6.unitest框架如何做测试?
管理测试用例。
测试用例类继承unittest.TestCase
unittest.main()运行所有测试用例
unittest.TestSuite()创建测试套
unittest.defaultTestLoader()运行测试ddu
跳过测试用例注解@unittest.skip(reason)
setup teardown 方法
断言方法
7.pytest框架?
在组织测试用例方面更灵活。它可以自定义标签来决定运行哪些用例。如果运行失败了再执行几次。
可以把公用的功能写在conftest.py文件中,一般把fixture函数写在这里面,如果是只执行一次的话,可以设置为session级别。
8.requests
它是第三方库。
可以发http协议的请求。各个方法的都支持。get,post。
get传参有两种方式:拼接在url后面传参,params方式传参。也可以携带请求头,cookie等。
post传参两种方式,data,json. data可以是字典。默认content-type为form。如果data是字符串,则还要在请求头中指明了application/json. json无论是json字符串还是json对象,默认content-type都是application/json
获取响应最常用的是j.json(),可以在这里面提取要断言的内容。如果响应为文件的话,响应这样获取j.content().其它一般情况下是j.text()
对于cookie的处理有两种。一种是直接获取cookie,携带cookie的方式。一种是用session的这种方式。
9.https协议403代表含义
类别 原因短语
1XX Informational(信息性状态码) 接受的请求正在处理
2XX Success(成功状态码) 请求正常处理完毕
3XX Redirection(重定向状态码) 需要进行附加操作以完成请求
4XX Client Error(客户端错误状态码) 服务器无法处理请求
5XX Server Error(服务器错误状态码) 服务器处理请求出错
2XX——表明请求被正常处理了
1、200 OK:请求已正常处理。
2、204 No Content:请求处理成功,但没有任何资源可以返回给客户端,一般在只需要从客户端往服务器发送信息,而对客户端不需要发送新信息内容的情况下使用。
3、206 Partial Content:是对资源某一部分的请求,该状态码表示客户端进行了范围请求,而服务器成功执行了这部分的GET请求。响应报文中包含由Content-Range指定范围的实体内容。
3XX——表明浏览器需要执行某些特殊的处理以正确处理请求
4、301 Moved Permanently:资源的uri已更新,你也更新下你的书签引用吧。永久性重定向,请求的资源已经被分配了新的URI,以后应使用资源现在所指的URI。
5、302 Found:资源的URI已临时定位到其他位置了,姑且算你已经知道了这个情况了。临时性重定向。和301相似,但302代表的资源不是永久性移动,只是临时性性质的。换句话说,已移动的资源对应的URI将来还有可能发生改变。
6、303 See Other:资源的URI已更新,你是否能临时按新的URI访问。该状态码表示由于请求对应的资源存在着另一个URL,应使用GET方法定向获取请求的资源。303状态码和302状态码有着相同的功能,但303状态码明确表示客户端应当采用GET方法获取资源,这点与302状态码有区别。
当301,302,303响应状态码返回时,几乎所有的浏览器都会把POST改成GET,并删除请求报文内的主体,之后请求会自动再次发送。
7、304 Not Modified:资源已找到,但未符合条件请求。该状态码表示客户端发送附带条件的请求时(采用GET方法的请求报文中包含If-Match,If-Modified-Since,If-None-Match,If-Range,If-Unmodified-Since中任一首部)服务端允许请求访问资源,但因发生请求未满足条件的情况后,直接返回304.。
8、307 Temporary Redirect:临时重定向。与302有相同的含义。
4XX——表明客户端是发生错误的原因所在。
9、400 Bad Request:服务器端无法理解客户端发送的请求,请求报文中可能存在语法错误。
10、401 Unauthorized:该状态码表示发送的请求需要有通过HTTP认证(BASIC认证,DIGEST认证)的认证信息。
11、403 Forbidden:不允许访问那个资源。该状态码表明对请求资源的访问被服务器拒绝了。(权限,未授权IP等)
12、404 Not Found:服务器上没有请求的资源。路径错误等。
5XX——服务器本身发生错误
13、500 Internal Server Error:貌似内部资源出故障了。该状态码表明服务器端在执行请求时发生了错误。也有可能是web应用存在bug或某些临时故障。
14、503 Service Unavailable:抱歉,我现在正在忙着。该状态码表明服务器暂时处于超负载或正在停机维护,现在无法处理请求。
10.正则表达式 match与 search 的区别
import re
#search可以不从位置0开始匹配。match必须从位置0开始匹配,否则就返回None
# username = '#jerry_friend'
username = 'jerry_friend'
m = re.match(r'\w{8,20}', username)
print(m)
print(m.span())
print(m.group())
username = '#jerry_friend'
m = re.search(r'\w{8,20}', username)
print(m)
print(m.span())
print(m.group())
11.linux创建文件?
touch
vi 文件名 :x 保存
12.获取查看动态日志
tail -f
13.防火墙
开启关闭端口号
14.jmeter性能测试
先进行性能需求分析,主要要考虑的问题是:要不要做,用什么工具做。具体的性能指标是什么,哪些功能需要做性能测试。然后开会评审性能指标是否正确,目前是否有环境可供做性能测试。
然后写设计测试用例。主要考虑的是单业务和综合业务的负载测试,压力测试,基准测试。稳定性测试。测试用例写清楚各个接口的步骤,场景,要不要加集合点,并发数是多少,思考时间是什么。
开发脚本。一般情况下录制脚本。然后优化脚本,进行参数化,加思考时间,集合点等。调试脚本,设置并发数等。
15.测试流程,测试设计
测试流程:需求评审,提取需求点,设计测试用例,准备测试环境,执行测试。提bug,回归bug。定版
测试用例常用设计方法:场景法。边界值分析,等价类划分,错误推测法。正交法
16.需求分析时要考虑的点,如何做?
是否符合用户的显性的及隐性的需求。
功能要求,性能要求,安全性要求,可靠性要求。数据的定义,接口的定义
17.需求评审有没参加过?
遗漏的需求,错误的需求,异常的需求。各种组合条件下的需求
18.web应用组件?apach http有没用过。nginx
做反向代理服务器和负载均衡服务器
19.shell脚本?echo?if格式?while?
num1=100
num2=100
if test $[num1] -eq $[num2]
then
echo '两个数相等!'
else
echo '两个数不相等!'
fi
for loop in 1 2 3 4 5
do
echo "The value is: $loop"
done