Python编程作业四:文件操作

目录

一、程序填空1

二、程序填空2

三、众数及词频统计

四、输入古诗并保存


编程素材下载地址:

链接:https://pan.quark.cn/s/86265d8aafc1
提取码:sDpr


一、程序填空1

        下面的程序是根据用户输入的星座名称,输出此星座的出生日期范围及对应的星座符号。星座及出生日期范围已存于文件 SunSign.csv 中,首先读入 CSV 文件中数据,循环获得用户输入,则输出此星座信息,直至用户输入 "exit" 程序结束。SunSign.csv 文件如图所示。

#根据输入,显示星座信息
fo = open("SunSign.csv","r", encoding='utf-8')
ls = []
for ______ in fo:                     #以“行”为单位进行处理
    line = line.replace("\n","")             #去掉行末的换行符
    ls._____(line.split(","))            #追加数据到ls列表
fo.close()

while True:                             #无限循环
    InputStr = input()                    #输入星座名称
    InputStr.strip()                      #去掉开头和结尾的空白
    flag = False                        #flag变量初始值为False
    if ______:                  #输入exit,结束循环
        break
    for line in ls:
        if InputStr == line[0]:             #line[0]中内容是星座名称
            #对输出结果进行格式化
            print("{}座的生日位于{}-{}之间"._____(chr(eval(line[3])),line[1],line[2]))
            flag = True                #输入星座正确,flag为True
    if flag == ______:
        print("输入星座名称有误!")

NO

Unicode编码

字符

1

9800

2

9801

3

9802

4

9803

5

9804

6

9805

7

9806

8

9807

9

9808

10

9809

11

9810

12 

9811

本题程序运行结果如下所示:

补充:程序倒数第4行中的 chr() 函数可以由表1第3列的 Unicode 编码得到对应的字符;而另一个相反的函数是 ord() 函数,它可以根据一个字符得到对应的 Unicode 编码。例如:chr(20013) 可以得到汉字“中”,而 ord(“中”) 则得到其编码是 20013 。

#根据输入,显示星座信息
fo = open("SunSign.csv","r", encoding='utf-8')
ls = []
for line in fo:                     #以“行”为单位进行处理
    line = line.replace("\n","")             #去掉行末的换行符
    ls.append(line.split(","))            #追加数据到ls列表
fo.close()

while True:                             #无限循环
    InputStr = input()                    #输入星座名称
    InputStr.strip()                      #去掉开头和结尾的空白
    flag = False                        #flag变量初始值为False
    if InputStr == "exit":                  #输入exit,结束循环
        break
    for line in ls:
        if InputStr == line[0]:             #line[0]中内容是星座名称
            #对输出结果进行格式化
            print("{}座的生日位于{}-{}之间".format(chr(eval(line[3])),line[1],line[2]))
            flag = True                #输入星座正确,flag为True
    if flag == False:
        print("输入星座名称有误!")

运行结果:

二、程序填空2

        下面的程序是统计并输出传感器采集数据中光照部分的最大值、最小值和平均值,所有值保留小数点后2位。已知传感器采集数据文件为 sensor-data.txt ,其中每行是一个整体数据,分别包括“日期、时间、温度、湿度、光照和电压”等6个读数,光照数据处于第5列,在列表中表示时下标应为4。

#根据数据,统计光照数据
f = open("sensor-data.txt", "r")
avg, cnt = 0, 0
maxv, minv = 0, 9999           #最大值、最小值变量的初始值
for line in ______:
    ls = line.split()
    cnt += 1
    val = eval(ls[____])      #将第5列数据存于val变量中
    avg += val                 #累加光照值到avg
    if val _____ maxv:
        maxv = val             #maxv中是光照的最大值
    if val <minv:
        minv = val             #minv中是光照的最小值
#以2位小数格式显示最大值、最小值、平均值
print("最大值、最小值、平均值分别是:{:.2f},{:.2f},{:.2f}".\
      format(maxv, minv, ______))
f.______()

本题程序运行结果如下所示:

#根据数据,统计光照数据
f = open("sensor-data.txt", "r")
avg, cnt = 0, 0
maxv, minv = 0, 9999           #最大值、最小值变量的初始值
for line in f:
    ls = line.split()
    cnt += 1
    val = eval(ls[4])      #将第5列数据存于val变量中
    avg += val                 #累加光照值到avg
    if val > maxv:
        maxv = val             #maxv中是光照的最大值
    if val < minv:
        minv = val             #minv中是光照的最小值
#以2位小数格式显示最大值、最小值、平均值
print("最大值、最小值、平均值分别是:{:.2f},{:.2f},{:.2f}".format(maxv, minv, avg/cnt))
f.close()

运行结果:

三、众数及词频统计

        文件 data.txt 中给出了一组数,请求出这组数的众数(众数指出现次数最多的那个数)及其出现的频率。

本题程序运行结果如下所示:

# 找出众数及其出现的频率
f=open("data.txt","r")
s=f.read()
nums=s.split(",")
d={}
for num in nums:
    d[num]=d.get(num,0)+1
ls=list(d.items())
ls.sort(key=lambda x:x[1],reverse=True)
print("众数是{},它出现的频率是{}".format(ls[0][0],ls[0][1]))

运行结果:

        这段代码可以找出给定数据中的众数及其出现的频率。但是,如果有多个数的出现频率相等,该怎么办呢?建议对代码进行一些修改,使其能够处理这种情况。以下是修改后的代码:

f=open("data.txt","r")
s=f.read()
nums=s.split(",")
d={}
for num in nums:
    d[num]=d.get(num,0)+1
ls=list(d.items())
ls.sort(key=lambda x:x[1],reverse=True)
max_freq = ls[0][1]
mode_list = [ls[0][0]]
for i in range(1, len(ls)):
    if ls[i][1] == max_freq:
        mode_list.append(ls[i][0])
    else:
        break
if len(mode_list) == 1:
    print("众数是{},它出现的频率是{}".format(mode_list[0], max_freq))
else:
    modes = ", ".join(mode_list)
    print("众数有{},它们出现的频率是{}".format(modes, max_freq))

        这段代码首先打开名为 "data.txt" 的文件,并读取其中的内容。然后将数据以逗号分隔,存储在一个列表中。接下来,使用字典d来统计每个数字出现的频率。然后将字典转换为包含键值对的列表 ls ,并按值(出现频率)进行降序排序。

        接着,程序获取出现频率最高的数字,并将其放入 mode_list 列表中。然后程序遍历排序后的列表,查找是否还有其他数字具有相同的最大频率,如果有,则将它们也添加到 mode_list 中。最后,程序检查 mode_list 中的数字数量,如果只有一个数字,则输出单数形式的结果,否则输出复数形式的结果,表示所有众数及其出现的频率。 

四、输入古诗并保存

        请从键盘输入一首5言绝句或者7言绝句,并把它保存在一个名为 poem.txt 的文件中,要求诗的标题和作者单独占一行,诗的内容每句占一行。输入的效果类似于下面左图所示,生成的文件内容如下面右图所示。

            

f=open("poem.txt","w")
poem=[]
title=input("请输入诗的名字:")
poem.append(title+'\n')
author=input("请输入诗的作者:")
poem.append(author+'\n')
for i in range(1,5):
    sentence=input("输入该诗的的第{}句:".format(i))
    poem.append(sentence+'\n')
f.writelines(poem)
f.close()

运行结果:

        这段代码可以让用户输入一首诗的相关信息(标题、作者、四句诗句),然后将这些信息写入到名为 "poem.txt" 的文件中。代码中使用了 open("poem.txt", "w") 来打开文件,并传入 "w" 参数,表示以写入模式打开文件。然后,通过 input() 函数分别获取用户输入的诗的标题和作者,并将它们存储在 poem 列表中。

        接下来,通过一个循环,让用户输入该诗的四句诗句,并将它们追加到 poem 列表中。注意,在每个输入的诗句后面添加了换行符 \n ,以确保每行只有一句诗。

        最后,使用 f.writelines(poem) 将 poem 列表中的内容写入到文件中,并通过 f.close() 关闭文件。这样,用户输入的诗就会被写入到 "poem.txt" 文件中了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Francek Chen

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

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

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

打赏作者

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

抵扣说明:

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

余额充值