2023-09 Python五级真题
分数:100
题数:38
测试时长:60min
一、单选题(共25题,共50分)
1. 阅读以下代码,程序输出结果正确的选项是?( C)(2分)
def process_keywords(keywords_list):
unique_keywords = list(set(keywords_list))
sorted_keywords = sorted(unique_keywords)
result = tuple(sorted_keywords)
return result
keywords = ["节约能源", "循环利用", "清洁能源", "减少污染", "植树造林","清洁能源"]
print(process_keywords(keywords)
A.('节约能约', '循环利用', '减少污染', '清洁能源', '减少污染')
B.('循环利用', '植树造林', '减少污染', '清洁能源', '清洁能源')
C.('减少污染', '循环利用', '植树造林', '清洁能源', '节约能源')
D.('植树造林', '循环利用', '节约能源', '清洁能源', '节约能源')
答案解析:将关键词列表转换为集合(set),去除重复的关键词,对去重后的关键词集合进行排序,将排序后的关键词列表转换为元组,输出。
2. 给定一个集合 s = {1, 2, 3, 4, 5},以下哪个选项可以实现从s 中移除所有偶数元素的功能?(D )(2分)
A.{x for x in s if x % 2 == 0}
B.s.filter(lambda x: x % 2 == 0)
C.{x % 2 != 0 for x in s}
D.set(filter(lambda x: x % 2 != 0, s))
答案解析:使用 filter() 函数可以过滤掉集合中的偶数,再用 set() 函数将过滤后的结果重新转换为集合类型。
3. 下列代码的运行结果是?(D )(2分)
tup = (1, 2, 3, 4, 5)
tup[2] = 10
print(tup)
A.(1, 2, 3, 4, 5)
B.(1, 2, 10, 4, 5)
C.(1, 10, 3, 4, 5)
D.抛出TypeError的异常
答案解析:本题属于较难题,如果tup是列表,在列表中可以通过tup[2] = 10改变列表元素的值。但是本题中, tup = (1, 2, 3, 4, 5) 的作用是定义一个元组, 元组不能通过直接赋值来改变元组元素的值 ,语句tup[2] = 10错误。
4. tuple1 = ('aa', 'bb', 'cc', '22'),则tuple1.index('22')的值是?(C )(2分)
A.1
B.2
C.3
D.4
答案解析:元组与列表和字符串一样,索引下标从0开始 ,最后一个元素“22“的索引下标是3。
5. Time模块中,time.time()所得的结果的数据类型是?(B )(2分)
A.整形
B.实型
C.字符串类型
D.列表类型
答案解析:time.time() 是 Python 中的一个内置函数,用于获取当前时间的时间戳(从 1970 年 1 月 1 日 00:00:00 到当前时间的秒数)。时间戳是一个浮点数,例如 1605012765.39698,时间戳就是一串数字,表示从某个固定时间点开始到现在的时间长度,通常以秒为单位计算。
6. Python中jieba的功能描述,正确的是?( A)(2分)
A.分词
B.数据可视化
C.计算
D.画图
答案解析:jieba 是Python中一个重要的第三方中文分词函数库,可以把一句话拆分成多个词,也可以从一句话(一段话)中提取最重要的几个关键词 ,答案选A
7. 小张编写一款石头剪子布游戏时,导入random库并将b赋值为["剪刀","石头","布"],不能实现随机产生b列表中一个元素的表达式是?(A )(2分)
A.b[random.random()*3]
B.random.sample(b,1)
C.b[random.randint(0,2)]
D.random.choice(b)
答案解析:此题属于较难题,考查随机函数的应用,难度在于通过生活中大家熟悉的一个实例,考查了多个随机函数,需要学生掌握这些随机函数的作用、功能,以及所产生序列的范围。选项B,random.sample(b,k) ,从序列b中随机选出k个元素,当k=1时,则随机选出1个元素,符合题目要求。选项C,random.randint(0,2),产生一个[0,2]之间的整数,包含0和2,也就是产生“0,1,2”之间的某个整数,符合题目要求。 选项D,random.choice(b)从序列b中选出一个元素,符合题目要求。选项A, random.random()*3产生的有可能是小数,而索引下标不能为小数,所以选项A错误。
8. 若要计算圆的面积,下列表达式肯定错误的是?(D )(2分)
A.s=math.pi*math.pow(r,2)
B.s=math.pi*r**2
C.s=math.pi*r*r
D.s=math.pi*r^2
9. 下列程序的功能是?(D )(2分)
for i in range(100,1,-2):
print(i)
A.顺序输出1-100以内的偶数
B.顺序输出1-100以内的奇数
C.倒序输出1-100以内的奇数
D.倒序输出1-100以内的偶数
10. Python使用range可以创建数值列表。下面可以正确输出600以内6的倍数的语句是?(D )(2分)
A.print(list(range(100, 600, 6)))
B.print(list(range(0, 600, 10)))
C.print(list(range(1, 601, 6)))
D.print(list(range(6, 601, 6)))
11. 学校气象站记录了周一到周日的PM2.5的数据
pminfo=[82,57,91,67,103,79,99]
根据需求,输出周日、周六、周五三天PM2.5数据的程序代码是?(B)(2分)
A.print(pminfo[7:5:-1])
B.print(pminfo[-1:3:-1])
C.print(pminfo[-1:5:7])
D.print(pminfo[5:7:-1])
12. 回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。下面可以正确打印三位回文数的语句是?( D)(2分)
A.print(i for i in range(100,999) if str(i) == str(i)[::-1])
B.print([i for i in range(1,1000) if str(i) == str(i)[::-1]])
C.print([i for i in range(1,999) if str(i) == str(i)[::-1]])
D.print([i for i in range(100,1000) if str(i) == str(i)[::-1]])
13. 下列哪个选项是正确的关于Python列表的定义?(A )(2分)
A.列表是有序的、可变动的元素集合
B.列表是有序的、不可变动的元素集合
C.列表是无序的、可变动的元素集合
D.列表是无序的、不可变动的元素集合
答案解析:Python列表是有序的,可以按照插入的顺序访问元素。同时,列表是可变动的,即可以通过添加、删除、修改元素来改变列表的内容。
14. 假设有一个列表l= [1, 2, 3, 4, 5],下面哪个操作可以移除列表中的第一个元素?(B )(2分)
A.l. pop(1)
B.l.remove(1)
C.del l[1]
D.l.clear()
答案解析:A项弹出索引号为1的元素,B项移除值为1的元素,C项删除索引号为1的元素,D项清空所有元素。故B项正确。
15. 下面哪个选项是用于获取列表中元素个数的方法?(D )(2分)
A.length()
B.size()
C.count()
D.len()
答案解析:len()函数用于获取列表中元素的个数。
16. 下列哪个选项是正确的列表切片操作?(A )(2分)
A.list[1:3]
B.list[1,3]
C.list[1-3]
D.list[1+3]
答案解析:列表切片操作可以用来获取列表中的一部分元素。切片操作使用[start:end]的形式,其中start表示起始索引(包含),end表示结束索引(不包含)。所以list[1:3]表示获取索引1和2的元素。
17. 以下哪个选项可以创建一个列表,包含数字 1 到 10 的平方?(A )(2分)
A.[x*x for x in range(1, 11)]
B.{x*x for x in range(1, 11)}
C.(x*x for x in range(1, 11))
D.
答案解析:列表推导式可以用于创建一个列表,并按照指定的表达式对迭代器进行转换。选项 A 使用列表推导式创建了一个包含 1 到 10 的平方的列表。
18. 以下哪个选项可以创建一个集合,包含 1 到 10 的奇数?(B )(2分)
A.{x for x in range(1, 11)} if x % 2 != 0
B.{x for x in range(1, 11) if x % 2 != 0}
C.[x for x in range(1, 11) if x % 2 != 0]
D.[x for x in range(1, 11)] if x % 2 != 0
答案解析:集合推导式可以用于创建一个集合,并按照指定的条件对迭代器进行筛选。选项 B 使用集合推导式创建了一个包含 1 到 10 的奇数的集合。
19. 下面的集合推导式将会生成什么集合?(A )(2分)
st = {x%2 for x in range(10)}
A.{0, 1}
B.{0, 2, 4, 6, 8}
C.{1, 3, 5, 7, 9}
D.{0, 1, 2, 3, 4, 5, 6, 7, 8, 9}
答案解析:该集合推导式将会生成 {0, 1} 这个集合,即将 0 到 9 的每个数对2取模并去重得到的集合。
20. 下面代码的执行结果是?( A)(2分)
knights = {'孙坚': '江东猛虎', '孙策': '小霸王'}
for k, v in knights.items():
print("大将:{},绰号:{}".format(k, v))
A.
大将:孙坚,绰号:江东猛虎
大将:孙策,绰号:小霸王
B.大将:孙坚,大将:孙策
C.大将:孙坚,绰号:孙策
D.绰号:江东猛虎,绰号:小霸王
答案解析:
knights.items()获得字典中的键值对。
for k, v in knights.items()分别获得键和值。
print("大将:{},绰号:{}".format(k, v))格式化字符串分别填入键和值。
21. 以下程序的输出结果是?(A )(2分)
dict = {'Name': 'Angel', 'Age': 8}
print(dict.items())
A.dict_items([('Age', 8), ('Name', 'Angel')])
B.[('Age', 8), ('Name', 'Angel')]
C.('Age', 8), ('Name', 'Angel')
D.'Age':8, 'Name': 'Angel'
答案解析:items()方法返回的结果是items对象。字典是无序的,因此有可能顺序会改变。虽然实际运行的结果可能不是这样的。
22. Python表达式("5"+"2")*2的运算结果是?( B)(2分)
A.14
B."5252"
C."522"
D.语法错误,程序报错
答案解析:B 本题考察+及*在字符串中的应用,+表示拼接,*表示重复。
23. 字符串变量s中存有小李身份证号码(s="331004200608160037",其中7至14位"20060816"代表出生日期)。若想提取小李身份证中的出生日期,下列Python表达式有错误的是?( C)(2分)
A.s[-12:-4]
B.s[6:14]
C.s[7:15]
D.s[6:-4]
24. 下列不可以正确输出语句"我叫 小明 今年 10 岁!"的Python语句的是?( C)(2分)
A.print ("我叫{name}今年{age}岁!" .format (age=10,name='小明'))
B.print ("我叫{}今年{}岁!" .format('小明', 10))
C.print ("我叫%s今年%s岁!" % (10,'小明'))
D.print ("我叫%s今年%d岁!" % ('小明', 10))
25. 运行代码print(r"\nPython")的结果是?(B )(2分)
A.直接输出:"\nPython"
B.直接输出:\nPython
C.直接输出:Python
D.先换行,然后在新的一行中输出:Python
二、判断题(共10题,共20分)
26. 集合类型中的元素必须是唯一的。( 对)
答案解析:集合中的元素必须是唯一的,如果添加了重复的元素,只会保留一个元素。可以使用集合类型来去除列表或元组中的重复元素。
27. 集合是有序的数据结构,可以根据元素的插入顺序进行遍历。(错 )
答案解析:集合是无序的,元素的遍历没有固定的顺序。
28. 元组是Python的不可变序列类型,意味着一旦你创建了一个元组,就不能进行插入、删除等操作。( 对)
答案解析:元组是Python的不可变序列类型,不能进行插入、删除元素等操作。
29. time库是Python中处理时间的标准库, time库中时间获取函数time()和ctime(),返回的都是字符串。(错 )
答案解析:Python中有三个函数可以获取当前系统的时间,分别是time()、ctime()、gmtime()。time()函数,返回的是一个浮点数,表示从1970年1月1日0点0分开始,到当前时间,一共经历了多少秒。ctime()返回易读的字符串形式。
30. 有如下Python程序段:
s=0
for i in range(1,11):
if i%5==3:
continue
s+=i
执行程序后,输出s的值是52。(错 )
答案解析:本题变量s的值为序列1到10中对5取余不等于3的数之和,值为44。
31. Python中的列表是可变的数据类型。(对 )
答案解析:列表是可变的,即可以通过修改、添加、删除元素来改变列表的内容。与之相对的是不可变的数据类型,例如字符串。
32. [x for x in range(5)] 是一个列表推导式。( 对)
答案解析:[x for x in range(5)] 是一个列表推导式,它通过循环生成一个包含0到4的整数列表。
33. 可以通过update()方法将一个字典的内容添加到另一个字典中。( 对)
答案解析:update()方法的用法。
34. 有字符串s=“happy national day”,s.find('na')返回值为-1。(错 )
答案解析:检测参数是否包含在字符串中,如果包含,返回开始的索引值,否则返回-1。字符串中包含“na”,因此返回6。
35. 小明想单独输出一个双引号,可以使用语句print("\"")进行输出。(对 )
三、编程题(共3题,共30分)
36. 已知有一些学生数据,每名学生的信息是一个字典。所有学生信息放在列表中。
(1)计算每个学生的平均分(语文+数学+英语)/3,并对平均分取整,追加到其字典;
(2)根据学生的平均分从低到高排列;
(3)输出每位学生的学号和平均分。
输出格式如下:
20230103:72
20230102:82
20230101:92
程序模板如下:
students= [{'学号':'20230101','语文': 90,'数学':95,'英语':92},{'学号':'20230102','语文': 80,'数学':85,'英语':82},{'学号':'20230103','语文': 70,'数学':75,'英语':72}]
for student in students:
_____①_____
students.sort(key = lambda x:x['平均分'],reverse = False)
for student in students:
print('{}:{}'.format( ____②_____ , _____③_____))
参考程序:
students= [{'学号':'20230101','语文': 90,'数学':95,'英语':92},
{'学号':'20230102','语文': 80,'数学':85,'英语':82},
{'学号':'20230103','语文': 70,'数学':75,'英语':72}]
for student in students:
student['平均分']=(student['语文']+student['数学']+student['英语'])//3
students.sort(key = lambda x:x['平均分'],reverse = False)
for student in students:
print('{}:{}'.format(student['学号'],student['平均分']))
评分标准:
(1)student['平均分']=(student['语文']+student['数学']+student['英语'])//3 或等效答案;(4分)
(2)student['学号'] 或等效答案;(3分)
(3)student['平均分'] 或等效答案。(3分)
37. 信息科技社团正在进行一种字符串扩展的实验,实验操作方法如下:
(1)给定一个初始字符串s,筛选出其中的大小写字母,生成新的字符串x;
(2)将字符串x最后一个字符删除,生成一个新的字符串y;
(3)将字符串x的右边最后一个字符拼接到字符串x的末尾;
(4)将字符串y拼接到字符串x的末尾。
按照(2)-(4)步骤重复操作,每一步将当前字符串的长度加倍,直到字符串x长度达到n。
给定初始字符串和n,请帮助社团同学们计算扩展的字符串中第n个位置的字符。
以s=“c1ar23”,n=8 为例
c1ar23 --> car --> carrca --> carrcaacarrc
第8个位置上的字符'c',则输出为c
输入格式:
第一行,一个字符串s(长度不超过20)
第二行,一个整数n(1<=n<=100)
输入样例:
c1ar23
8
输出格式:
一个字符,表示扩展的字符串中的第n个字符。
输出样例:
c
s=input()
n=int(input())
x=""
for i in s:
if ((i>='A' and i<='Z') _____①______):
x=x+i
xn=len(x)
while xn
参考程序:
s=input()
n=int(input())
x=""
for i in s:
if ((i>='A' and i<='Z')or(i>='a' and i<='z')):
x=x+i
xn=len(x)
while xn
评分标准:
(1)or(i>='a' and i<='z')或等效答案;(2分)
(2)x[-1]或等效答案;(2分)
(3)len(x)或等效答案;(3分)
(4)x[n-1]或等效答案。(3分)
38. 编写Python程序,要求输出区间[m,n]内所有素数的和,实现上述功能的 Python 程序如下,请在划线处填入合适的代码。
def isPrime(num): #判断素数
num=int(num)
for i in range(2,num):
if _____①______:
return False
if num!=1:
return True
def PrimeSum(a,b):
sum=0
for i in range(a,b+1):
if isPrime(i):
_______②___________
return sum
m=int(input("m:"))
n=int(input("n:"))
print(___________③________)
参考程序:
def isPrime(num):
num=int(num)
for i in range(2,num):
if num%i==0:
return False
if num!=1:
return True
def PrimeSum(a,b):
sum=0
for i in range(a,b+1):
if isPrime(i):
sum+=i
return sum
m=int(input("m:"))
n=int(input("n:"))
print(PrimeSum(m,n))
①函数isPrime(num)用于判断num是否为素数,返回True表示num是素数,返回False表示num不是素数,不是素数说明num能被1和自身之外的其他数整除,应填入的代码为num%i==0;
②满足函数isPrime(i)时所执行累加到sum中的操作,应填入的代码为sum+=i。
③此处为自定义函数的调用,调用PrimeSum函数计算素数和。
评分标准:
(1)num%i==0;(4分)
(2)sum+=i;(3分)
(3)PrimeSum(m,n)。(3分)