首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
考生文件夹下存在3个Python源文件,分别对应3个问题;1个文本文件,作为本题目输入数据,请按照源文件内部说明修改代码,实现以下功能: 《卖火柴的小女孩》是丹麦童话故事作家安徒生的一篇童话故事,发表于1846年。主要讲了一个卖火柴的小女孩在富人阖
考生文件夹下存在3个Python源文件,分别对应3个问题;1个文本文件,作为本题目输入数据,请按照源文件内部说明修改代码,实现以下功能: 《卖火柴的小女孩》是丹麦童话故事作家安徒生的一篇童话故事,发表于1846年。主要讲了一个卖火柴的小女孩在富人阖
admin
2020-04-10
94
问题
考生文件夹下存在3个Python源文件,分别对应3个问题;1个文本文件,作为本题目输入数据,请按照源文件内部说明修改代码,实现以下功能:
《卖火柴的小女孩》是丹麦童话故事作家安徒生的一篇童话故事,发表于1846年。主要讲了一个卖火柴的小女孩在富人阖家欢乐、举杯共庆的大年夜冻死在街头的故事。这里给出《卖火柴的小女孩》的一个网络版本文件,文件名为“小女孩.txt”。
问题1:在PY301—1.py文件中修改代码,对“小女孩.txt”文件进行字符频次统计,输出频次最高的中文字符(不包含标点符号)及其频次,字符与频次之间采用英文冒号”:”分隔,将输出结果保存在考生文件夹下,命名为"PY301—1.txt"。示例格式如下:
的:83
试题程序:
#以下代码为提示框架
#请在…处使用一行或多行代码替换
#请在________处使用一行代码替换
#注意:提示框架代码可以任意修改,以完成程序功能为准
fo=open(”PY3 01—1.txt”,”w”)
d={}
fo.write(”{}:{}”.format(__________))
fo.close()
问题2:在PY301—2.py文件中修改代码,对“小女孩.txt”文件进行字符频次统计,按照频次由高到低,输出前10个频次最高的字符,不包含回车符,字符之间无间隔,连续输出,将输出结果保存在考生文件夹下,命名为“PY301—2.txt”。示例格式如下:
,的一…(后略,共10个字符)
试题程序:
#以下代码为提示框架
#请在…处使用一行或多行代码替换
#注意:提示框架代码可以任意修改,以完成程序功能为准
fo=open(”PY301一2.txt”,“w”)
d={}
ls=list(d.items())
ls.sort(key=lambda x:x[1],reverse=True)#此行可以按照词频由高到低排序
问题3:在PY301一3.py文件中修改代码,对“小女孩.txt”文件进行字符频次统计,将所有字符按照频次从高到低排序,字符包括中文、标点、英文等符号,但不包含空格和回车。将排序后的字符及频次输出到考生文件夹下,文件名为“小女孩一频次排序.txt”。字符与频次之间采用英文冒号”:”分隔,各字符之间采用英文逗号”,”分隔,参考CSV格式,最后无逗号,文件内部示例格式如下:
着:30,那:29,火:29
试题程序:
#以下代码为提示框架
#请在…处使用一行或多行代码替换
#注意:提示框架代码可以任意修改,以完成程序功能为准
d={}
ls=list(d.items())
ls.sort(key=lambda x:x[1],reverse=True)}}此行可以按照词频由高到低排序
…
选项
答案
(1)fi=open("小女孩.txt","r") fo=open(”PY301—1.txt”,”w”) txt=fi.read() d= {} exclude=",。!?、()【】<>《》=:+-*-“”…" for word in txt: if word in exclude: continue else: d[word]=d.get(word,0)+1 ls=list(d.items()) ls.sort(key=lambda x:x[1],reverse=True) fo.write(”{}:{}”format(ls[0][0],ls[0][1])) fo.close() (2)fi=open("小女孩.txt","r") fo=open(”PY301—2.txt”,”w”) txt=fi.read() d= {} for word in txt; d[word]=d.get(word,0)+1 del d["\n"] ls=list(d.items()) ls.sort(key=lambda x:x[1],reverse=True)#此行可以按照词频由高到低排序 for i in range(10); fo.write(ls[i][0]) fi.close() fo.close() (3) fi = open ("小女孩.txt","r") fo =open(小女孩-频次排序。txt","w") txt =fi.read() d = {} for word in txt d[word]=d.get(word,0)+1 del d[""] del d["\n"] ls=list(d.items()) ls.sort(key=lambda x:x[1],reverse=True)#此行可以按照词频由高到低排序 for i in range(len(ls)): ls[i]="{}:{}".format(ls[i][0],ls[i][1]) fo.write(",".join(ls)) fi.close() fo.close()
解析
(1)首先使用open()函数打开文件“小女孩.txt”,把文件的内容通过read()方法保存到变量txt中;定义一个字符串变量exclude用来存放标点符号。然后用for循环遍历txt中的每个字符(word),并使用if条件进行判断,若该字符在变量exclude中,说明该字符为标点符号,跳出该循环;否则将该字符作为字典d中的一个键,该键所对应的值置为1,在后面循环中只要遍历的字符与该键相同,就将该键对应的值加1。
ls=list(d.items())表示将字典类型变成列表类型,字典中的每个键值对对应列表中的一个元组。随后,对列表ls中的元组进行排序,用到sort()方法,参数“key=lambda.x:x[1]”中lambda是一个隐函数,是固定写法,不能写成别的单词;x表示列表中的一个元素,在这里表示一个元组,x只是临时起的一个名字,也可以使用任意的名字;x[1]表示以元组中第二个元素排序。sort()方法的第二参数表示是按哪种方式排序,若为“reverse=True”表示按降序排序;若该参数缺省或“reverse=False”,表示按升序排序。
排序后,列表ls中第一个元组中即为频次最高的中文字符和频次,ls[0][0]表示该字符,ls[0][1]表示其频次,将这两个元素通过“:”连接写入文件“PY301—1.txt”中。
(2)问题2和问题1的区别在于统计的字符包含标点符号,因此不需要设置字符串变量exclude和使用if条件语句进行判断;题目要求不包含回车符,因此需要使用del删除字典d中键为”\n”的元素。最后要无间隔输出前10个频次最高的字符,需要对排序好的列表ls进行for循环遍历,找到前10个元组的第一个元素,并将其直接写入到文件“PY301—2.txt”中。
(3)问题3和问题2的区别在于统计的字符中不能包含空格,因此需要使用del删除字典d中键为空格的元素。最后要将所有字符和其频次输出,需要对排序好的列表ls进行for循环遍历,遍历列表中的每个元组,并将元组中的两个元素通过“:”连接,再用逗号分隔每个字符写入到文件“小女孩一频次排序.txt”中。
转载请注明原文地址:https://kaotiyun.com/show/g86p777K
本试题收录于:
二级Python题库NCRE全国计算机二级分类
0
二级Python
NCRE全国计算机二级
相关试题推荐
(1)在考生文件夹下,将BOOKS表中所有书名中含有“计算机”3个字的图书复制到BOOKS_BAK表中,以下操作均在BOOKS_BAK表中完成。(2)复制后的图书价格在原价格的基础上降低5%。(3)从图书均价高于25元(含25)的出版社
在SQLSELECT语句中为了将查询结果存储到临时表应该使用短语()。
在VisualFoxPro中设计屏幕界面通常使用()。
一棵完全二叉树共有360个结点,则在该二叉树中度为1的结点个数为()。
说明数组后,数组元素的初值是()。
假设表文件TEST.DBF已经在当前工作区打开,要修改其结构,可使用命令()。
下面对软件测试描述错误的是()。
关闭释放表单的方法是()。
下面不属于软件测试实施步骤的是
以下选项中,Python网络爬虫方向的第三方库是
随机试题
Whichofthefollowingisusedtomeasureaperson’spotentialabilityoflearninganewlanguage?
URL
在有效管理中,起关键作用的是
内痔环切术常有的后遗症是:结扎法可能出现的术后并发症是:
离光源3m处的发光强度是100cd,在同一方向,离光源6m处的发光强度是()cd。
某企业一月份共发放职工工资300000元,并为职工交付医疗保险费等社会保险费共计80000元,交付住房公积金50000元,另外,还为职工发放公司自产产品作为福利,共计10000元。由上,该企业月末应付职工薪酬科目的增加额应为()元。
“这次顺利考上未必是好事,考不上也未必是坏事”,这句话反映的哲学思想是()。
()是一种最高层次的职业道德。
根据香农公式,以下关系正确的是()。
一个栈的初始状态为空。现将元素1、2、3、4、5、A、B、C、D、E依次入栈,然后再依次出栈,则元素出栈的顺序是
最新回复
(
0
)