平安科技软件测试笔试题-精品

笔试题有三份,分别考python、SQL、java和计算机网络Linux命令等基础知识。

python部分

1、选择题

第1题,下列选项中,python不支持的数据类型有(B

python中没有字符类型,只有字符串类型string

A、int            B、char           C 、float              D、dictionary

第2题,下列Python语句正确的是(D

考简单的python语句是否有错。按照语法就可以了

A. min = x if x < y else y           B. max = x > y ? x : y

C. if(x > y) print x                      D. while True :pass  (while后面加分号,pass语句空语句,不做任何事情)

2、简答题

、a = 1,b = 2 。不用中间变量交换a和b的值(同理,交换列表也一样)

a,b = b,a

、s ="ajldjlajfdljfddd",去重并从小到大排序输出 "adfjl"

方法1

# 由于数据类型set本身具有无序,唯一值的特性,可以用内置函数set对字符串和列表进行去重
s ="ajldjlajfdljfddd"
s1 = set(s) #去重
s2 = list(s1) #转为列表
s2.sort() #排序,注意没有返回值
s3 = ''.join(s2) #列表转字符串
print(s3) #输出

方法2

s ="ajldjlajfdljfddd"
s1 = set(s) #去重
s2 = list(s1) #转为列表
s3 = sorted(s2) #排序
s4 = ''.join(s3) #列表转字符串
print(s4) #输出

方法3,一行代码搞掂,熟悉的话应该很容易写。

s ="ajldjlajfdljfddd"
s1 =''.join(sorted(list(set(s))))
print(s1)

三、用至少三种方法从字符串"hello boy<[www.doiido.com]>byebye"中提取字符串'www.doiido.com'

①使用切片法截取字符串。切片语法:[起始:结束:步长],步长默认为1,可为负数,切片区间左闭右开

str = "hello boy<[www.doiido.com]>byebye"
print(str[11:25:1]) #第一个w第11位,最后m第24位,注意切片区间左闭右开

输出:

www.doiido.com

②使用split函数。

语法:str.split(str="", num=string.count(str))[n]
参数:str默认为空格
          num为分割次数
          [n]表示取第n个分片,可不写则不取,下标同样从零开始
返回值:分割后的字符串列表(列表元素=分割次数num+1)

思路:

   1. 网址在[]里面,用第一个 [ 将字符串分隔成列表 str.split("[")

 

['hello boy<', 'www.doiido.com]>byebye']

   2. 再取列表里的索引为1的元素  str.split("[")[1]

    

www.doiido.com]>byebye

   3. 再用分隔符]将列表分隔开  str.split("[")[1].split("]")

['www.doiido.com', '>byebye']

   4. 再取第一个元素  str.split("[")[1].split("]")[0]

 

www.doiido.com

代码:

str = "hello boy<[www.doiido.com]>byebye"
print(str.split("[")[1].split("]")[0])#是先输出[后的内容 以及]前的内容,下标从0开始

输出:

www.doiido.com

③使用replace函数

语法:str.replace(old, new[, max])
参数
1.old -- 这是要进行更换的旧子串。
2.new -- 这是新的子串,将取代旧的子字符串。
3.max -- 如果这个可选参数max值给出,就只替代max个,除max个外若还有old值,也不替代。
返回值:把新的子串取代旧的子串后,形成的新的字符串。
注意:并不返回原字符串里,请赋给一个新的string。

思路:

1. 网址在w之前的字符串用空格替换掉 str.replace('hello boy<[','')

www.doiido.com]>byebye

2. 网址在m后面的字符串用空格替换掉 str1.replace(']>byebye','')

www.doiido.com

代码:

str = "hello boy<[www.doiido.com]>byebye"
str1 = str.replace('hello boy<[','')#删除网址之前的字符串
print(str1.replace(']>byebye',''))#删除网址之后的字符串

输出:

www.doiido.com

④目前到这里。。。可能还有其他的函数楼主还没想到

四、读取testA.txt的内容,去掉文件中的空格,写入到testB.txt中。

语法:

1、打开文件或者新建一个文件(不指定访问方式,默认只读方式打开文件)

2、读/写数据

3、关闭文件

代码:

f1 = open('testA.txt','w') #新建testA.txt
f1.write('I am Quality Testing Engineer')#往testA.txt写数据
f1.close()#关闭文件
f2 = open('testA.txt','r')#读模式
content = f2.read()#读testA.txt数据
str = content.replace(" ","")#把数据中的空格全部去掉
f3 = open('testB.txt','w')#新建testB.txt
f3.write(str)#往testB.txt写数据
f2.close()#关闭文件
f3.close()#关闭文件

看看运行后py文件目录下的结果:

成功。注意读之前一定要关闭文件,否则读取会失败。可以删除f1.close()这一行代码试一试(运行后testB.txt内容为空)。

五、阅读下面的代码,写出A0,A1至An的值。

A0 = dict(zip(('a','b','c','d','e'),(1,2,3,4,5))) #先zip返回对象,再dict转字典
A1 = range(10) #即range(0,10,1)
A2 = [i for i in A1 if i in A0] #即[i for i in range(10) if i in A0],A0与A1交集
A3 = [A0[s] for s in A0] #即[A0[s] for s in A0.keys()],A0[s]字典知道键通过下标取值
A4 = [i for i in A1 if i in A3] #即 既满足A1,又满足A3,A1和A3交集
A5 = {i:i*i for i in A1}      #即{i:i*i for i in range(10)},字典键值对
A6 = [[i,i*i] for i in A1]    #即[[i:i*i] for i in range(10)],列表元素又是列表
print('A0:',A0)
print('A1:',A1)
print('A2:',A2)
print('A3:',A3)
print('A4:',A4)
print('A5:',A5)
print('A6:',A6)

话不多说,马上看看结果

A0: {'a': 1, 'b': 2, 'c': 3, 'd': 4, 'e': 5}
A1: range(0, 10)
A2: []
A3: [1, 2, 3, 4, 5]
A4: [1, 2, 3, 4, 5]
A5: {0: 0, 1: 1, 2: 4, 3: 9, 4: 16, 5: 25, 6: 36, 7: 49, 8: 64, 9: 81}
A6: [[0, 0], [1, 1], [2, 4], [3, 9], [4, 16], [5, 25], [6, 36], [7, 49], [8, 64], [9, 81]]

分析:考察列表推导式,详情见Python 列表推导式

A0:zip函数作用,dict函数作用。#先zip返回对象,再dict转字典

A1:range函数作用。#即range(0,10,1)

A2:for if 用法。#即[i for i in range(10) if i in A0],A0与A1交集

A3:取字典元素,for 用法。#即[A0[s] for s in A0.keys()],A0[s]字典知道键通过下标取值

A4:同A2。#即 既满足A1,又满足A3,A1和A3交集

A5:for 输出字典元素。#即{i:i*i for i in range(10)},字典键值对

A6:for 输出列表元素。#即[[i:i*i] for i in range(10)],列表元素又是列表

后面对这些函数单独研究。

SQL部分

请移步:学生各门课程成绩统计SQL语句大全(面试题)

 

 

 

 

 

 

  • 3
    点赞
  • 50
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

软件测试李同学

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值