首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
考生文件夹下存在两个Python源文件,分别对应两个问题,请按照文件内说明修改代码,实现以下功能: 下面所示为一套由公司职员随身佩戴的位置传感器采集的数据,文件名称为“sensor.txt”,其内容示例如下: 2016/5/31 0:05,
考生文件夹下存在两个Python源文件,分别对应两个问题,请按照文件内说明修改代码,实现以下功能: 下面所示为一套由公司职员随身佩戴的位置传感器采集的数据,文件名称为“sensor.txt”,其内容示例如下: 2016/5/31 0:05,
admin
2020-04-10
103
问题
考生文件夹下存在两个Python源文件,分别对应两个问题,请按照文件内说明修改代码,实现以下功能:
下面所示为一套由公司职员随身佩戴的位置传感器采集的数据,文件名称为“sensor.txt”,其内容示例如下:
2016/5/31 0:05,vawelon001,1,1
2016/5/31 0:20,earpa001,1,1
2016/5/31 2:26,eawa001,1,6
…(略)
第一列是传感器获取数据的时间,第二列是传感器的编号,第三列是传感器所在的楼层,第四列是传感器所在的位置区域编号。
问题1:在PY301一1.py文件中修改代码,读入sensor.txt文件中的数据,提取出传感器编号为earpa001的所有数据,将结果输出保存到“earpa001.txt”文件。输出文件格式要求:原数据文件中的每行记录写人新文件中,行尾无空格,无空行。参考格式如下:
2016/5/31 7:11,earpa001,2,4
2016/5/31 8:02,earpa001,3,4
2016/5/31 9:22,earpa001,3,4
…(略)
试题程序:
#以下代码为提示框架
#请在程序的…处使用一行或多行代码替换
#请在程序的_______处使用一行代码替换
#注意:提示框架代码可以任意修改,以完成程序功能为准
…
for line in______:
…
fo.write(’{},{},{},{}\n’.format(________))
…
问题2:在PY301—2.py文件中修改代码,读入“earpa001.txt”文件中的数据,统计earpa001对应的职员在各楼层和区域出现的次数,保存到“earpa001-count.txt”文件,每条记录一行,位置信息和出现的次数之间用英文半角逗号隔开,行尾无空格,无空行。参考格式如下。
1一1.5
1—4.3
…(略)
含义如下:
第1行“1一1,5”中1一1表示1楼1号区域,5表示出现5次;
第2行“1-4,3”中1-4表示1楼4号区域,3表示出现3次;
试题程序:
#以下代码为提示框架
#请在程序的…处使用一行或多行代码替换
#请在程序的_______处使用一行代码替换
#注意:提示框架代码可以任意修改,以完成程序功能为准
d=()
ls=list(d.items())
ls.sort(key=lambda x:x[1],reverse=True)#该语句用于排序
fo.write(’{),()\n’format(________))
选项
答案
(1)fi = open(’sensor.txt’,’r’) fo = open(’earpa001.txt’,’w’) txt = fi.readlines() for line in txt: ls=line.strip("\n").split(",") if ’earpa001’ in ls: fo.write(”{},{},{},{}\n”.format(ls[0],ls[1],ls[2],ls[3])) fi.close() fo.close() (2) fi=open(’earpa001.txt’,’r’) fo=open(’earpa001_count.txt’,’w’) d={} for line in fi: split_data = line.strip("\n").split(’,’) floor_and_area = split_data[-2] + "-" + split_data[-1] if floor_and_area in d; d[floor_and_area] + = 1 else; d[floor_and_area] + =1 ls=list(d.items()) ls.sort(key=lambda x:x[1],reverse=True)#该语句用于排序 for i in range(ls)); fo.write(’{},{}\n’.format(ls[i][0],ls[i][1])) fi.close() fo.close()
解析
(1)本题涉及sensor.txt和earpa001.txt两个文件,前者使用r模式打开,后者使用w模式创建。从文件sensor.txt中读入所有的行,以行为元素形成列表txt。然后使用for循环遍历列表txt中的每个元素,并将该元素内容存人到列表ls中。使用if条件判断“earpa001”是否在列表ls中,如果存在,就将列表ls中的前四个元素写入到文件earpa001.txt中。最后关闭文件。
(2)本题涉及earpa001.txt和earpa001_count.txt两个文件,前者使用r模式打开,后者使用w模式创建。由于题目涉及到统计计算,这可以借助字典来实现,因此首先定义字典变量d。
然后使用for循环遍历earpa001.txt的每一行,并将该行内容存入到列表split_data中,由于题目要求的格式形如“1—1”,因此需要将列表split_data中的最后两个元素通过“一”进行连接并赋值给变量floor_and_area。使用if条件判断floor_and_area在字典d中是否存在,若存在则将该键对应的值加1,若不存在则将变量作为字典的键并将对应值置为1。
ls=list(d.items())表示将字典类型变成列表类型,字典中的每个键值对对应列表中的一个元组。随后,对列表ls中的元组按照第二个元素的大小降序排序。
排序后,再通过一个for循环遍历将列表ls中每个元组的第一个和第二个元素写入到文件earpa001_count.txt中。最后关闭文件。
转载请注明原文地址:https://kaotiyun.com/show/pf6p777K
本试题收录于:
二级Python题库NCRE全国计算机二级分类
0
二级Python
NCRE全国计算机二级
相关试题推荐
(1)在考生文件夹下建立数据库BOOKAUTH.DBC,把表BOOKS和AUTHORS添加到该数据库中。(2)为AUTHORS表建立主索引,索引名为“PK”,索引表达式为“作者编号”。(3)为BOOKS表建立两个普通索引,第一个索引名为
“SELECT*FROM投稿表TOFILEtempwHERE审稿结果=’通过’语句的功能是()。
执行下列程序后,变量s的值是()。SETTAILKOFFCLEARx="12345"s=""l=LEN(x)DOWHlLEl>1x1=SUBSTR(x,l一1,2)
执行?CEILING(16\5)命令的结果是()。
在VisualFoxPro表中,为了放置照片信息合理使用的字段类型是()。
与“SELECT*FROM教师表INTODBFA”等价的语句是()。
学生表中有“学号”、?姓名”和“年龄”三个字段,SQL语句“SELECT学号FROM学生”完成的关系操作称为()。
在VisualFoxPro中,假设student表中有40条记录,执行下面的命令后,屏幕显示的结果是()。?RECCOUNT()
如果内存变量和字段变量均有变量名“姓名”,那么引用内存变量错误的方法是()。
下列函数中,函数值返回逻辑真(.T.)的是()。
随机试题
Twoshipswerebarely______onthehorizon.
A、Theyarewronglydefined.B、Theyinteractwitheachother.C、Theycanbeconfusingsometimes.D、Theyarereplaceablewitheach
A.相乘B.相克C.子病犯母D.相侮E.母病及子
COlles骨折肩关节脱位
关于辩论原则的表述,下列哪些选项是正确的?
关于危害结果的相关说法,下列哪一选项是错误的?
下列不属于基金财务会计报告分析目的的是()。
下列属于影响财务管理的经济环境因素的有()。
商标注册申请争议的解决机制是()。
IfyouliveinacityinNorthAmericaorEurope,youhaveprobablyneverthoughtmuchaboutwater.Wheneveryouneedsome,you
最新回复
(
0
)