首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
某班学生评选一等奖学金,学生的10门主干课成绩存在考生文件夹下文件score.txt中,每行为一个学生的信息,分别记录了学生学号、姓名以及10门课成绩,格式如下: 1820161043 郑珉镐 68 66 83 77 56 73 61 69 66
某班学生评选一等奖学金,学生的10门主干课成绩存在考生文件夹下文件score.txt中,每行为一个学生的信息,分别记录了学生学号、姓名以及10门课成绩,格式如下: 1820161043 郑珉镐 68 66 83 77 56 73 61 69 66
admin
2020-04-10
44
问题
某班学生评选一等奖学金,学生的10门主干课成绩存在考生文件夹下文件score.txt中,每行为一个学生的信息,分别记录了学生学号、姓名以及10门课成绩,格式如下:
1820161043 郑珉镐 68 66 83 77 56 73 61 69 66 78
1820161044 沈红伟 91 70 8l 91 96 80 78 9l 89 94
从这些学生中选出奖学金候选人,条件是:①总成绩排名在前10名;②全部课程及格(成绩大于等于60)。
问题1:给出按总成绩从高到低排序的前10名学生名单,并写入文件candidate0.txt,每行记录一个学生的信息,分别为学生学号、姓名以及10门课成绩。补充考生文件夹下文件PY301一1.py,完成这一功能。
试题程序:
#请在…处使用多行代码替换
#
#注意:其他已给出代码仅作为提示,可以修改
L=[] #L中的元素是学生原始成绩和总成绩
…#此处可多行
L.sort(key=lambda x:x[一1],reverse=True)拌按学生总成绩从大到小排序
…#此处可多行
问题2:读取文件candidate0.txt,从中选出候选人,并将学号和姓名写入文件candidate.txt,格式如下:
1010112161722 张三
1010112161728 李四
补充考生文件夹下文件PY301—2.py,完成这一功能。
试题程序:
’’’
输入文件:candidate0.txt
输出文件:candidate.txt
’’’
选项
答案
(1)L=[] fo=open("score.txt","r") fi=open("candidate0.txt","w") lines=fo.readlines() for line in lines: line=line.strip() student=line.split(’’) sum=0 for i in range(1,11): sum+=int(student[-i]) studene.append(str(sum)) L.append(student): L.sort(key=lambda.x:x[一1],reverse=True) for i in range(10): fi.write(’’,join(L[i][:-1])+’\n’) fo.close() fi.close() (2)’’’ 输入文件:candidate0.txt 输出文件:candidate.txt ’’’ fo=open("candidate0.txt","r") fi=open("candlidate.txt","w") L=[]#存储候选人 lines=fo.readlines() for line in lines: line=line.strip() student=line.split(’’) for i in student[-10:]: if int(i)<60: break else: I..append(student[:2]) for i in L: fi.write(’’.join(i)+’\n’) fo.close() fi.close()
解析
(1)本题涉及”score.txt”和”candidate0.txt”两个文件。首先要读取”score.txt”文件中的信息,通过程序求出每个学生的总成绩,然后按总成绩从大到小排序,将总成绩排名前10的学生的学号、姓名以及10门课成绩写入到”candidate0.txt”文件中。打开文件用open()函数,用”r”只读模式打开文件”score.txt”,用”w”模式创建文件”cand:idate0.txt”。
”score.txt”文件中每行为一个学生的信息,需要用readlines()函数读入所有行,以每行为元素形成列表lines,然后用for循环遍历该列表中的每个元素。在遍历每个元素时,用strip()方法删除元素首尾出现的空格,用split()方法以空格分隔学生的学号、姓名以及10门课成绩得到列表student。由于要求出总成绩,因此要使用for遍历每个学生的10门课成绩,将其累加赋值给sum,并将sum追加到student中。最后将student中所有元素追加到列表L中。
随后,对列表L中的元素进行排序,用到sort()方法,参数”key=lambda x:x[一1]”中lambda是一个隐函数,是固定写法,不能写成别的单词;x表示列表中的一个元素,在这里表示一个列表(即一个学生的信息),x只是临时起的一个名字,也可以使用任意的名字;x[一1]表示以列表中的最后一个元素(即总成绩)排序。参数”reverse=True”表示按降序排序;若该参数缺省或”reverse=False”,表示按升序排序。
最后,通过for循环在列表L中提取出前10个元素(即前10名的学生信息,但不包含总成绩),用空格分隔每个元素,并添加换行符,写入到文件”candidate0.txt”中,再关闭所有文件。
(2)本题涉及”candidate0.txt”和”candidate.txt”两个文件。首先要读取”candidate0.txt”文件中的信息,通过程序判断每个学生的所有课程成绩是否都大于等于60,满足条件的将该学生的学号和姓名写入到”candidate.txt”文件中。打开文件用open()函数,用”r”只读模式打开文件”candidate0.txt”,用”w”模式创建文件”candidate.txt”,并定义一个列表L来存储学号和姓名(做中转)。
”candidate0.txt”文件中有10行数据,需要用readlines()函数读入所有行,以每行为元素形成列表lines,然后用for循环遍历该列表中的每个元素。在遍历每个元素时,用strip()方法删除元素首尾的空格,用split()方法以空格分隔学生的学号、姓名以及10门课成绩得到列表student。然后对列表student使用for循环遍历,用来判断10门课程的成绩是否都大于等于60,满足条件就将列表student中的前两个元素(即学号和姓名)追加到列表L中。
最后,通过for循环提取列表L中的所有元素,用空格分隔每个元素,并添加换行符,写入到文件”candidate.txt”中,再关闭所有文件。
转载请注明原文地址:https://jikaoti.com/ti/qh50FFFM
本试题收录于:
二级Python题库NCRE全国计算机二级分类
0
二级Python
NCRE全国计算机二级
相关试题推荐
下面有关数据库表和自由表的叙述中,错误的是()。
下列数据结构中,属于非线性结构的是()。
假设会员表中包含会员号、姓名和电话字段。现在希望通过创建合适的索引来保证会员号的值唯一,下面选项中能够保证会员号的值是唯一的语句是()。
在VisualFoxPro中,下面关于属性、事件、方法叙述错误的是()。
假设“订单”表中有订单号、职员号、客户号和金额字段,如下SQL命令可以正确执行的是()。
在VisualFoxPro中,执行SQL的DELETE命令和传统的FoxProDELETE命令都可以删除数据库表中的记录,下面正确的描述是()。
假设客户表中有客户号(关键字)C1一C10共10条客户记录,订购单表有订单号(关键字)OR1^OR8共8条订购单记录,并且订购单表参照客户表。如下命令可以正确执行的是()。
下面关于工具栏的叙述,错误的是()。
表单名为myForm的表单中有一个页框myPageFrame,将该页框的第3页(Page3)的标题设置为“修改”,可以使用代码()。
下列度量单位中,用来度量计算机网络数据传输速率(比特率)的是
随机试题
You’re________yourtimetalkingtohim,becausehe’llneverunderstand.
下列哪种疾病是非器官特异性自身免疫疾病
牙尖的数目是由什么决定的
()是一种非商业性信贷,属于国家主权外债,由国家统一对外举措。
具有一定程度拥挤性的是( )。
教育制度就是学校教育制度。
DrugReactions--aMajorCauseofDeathAdversedrugreactionsmaycausethedeathsofover100,000UShospitalpatientseach
•Youwillhearapublicrelationsmanagertellingaboutthewaytommonthecharm.•Asyoulisten,forquestions1-12,complete
Ifyou【D1】______smoothskinthatglowswithyouth,thechancesarethatatsomepointyouwillhaveheardtheexhortationtodri
A、Allofthemareoverweight.B、Theycanalwayschoosetherightfood.C、Theystudyinmodernlife.D、Theyeatfoodswithtoomu
最新回复
(
0
)