Python编程作业四:文件操作

简介: Python编程作业四:文件操作

编程素材下载地址:

链接: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" 文件中了。


目录
相关文章
|
2月前
|
机器学习/深度学习 存储 设计模式
Python 高级编程与实战:深入理解性能优化与调试技巧
本文深入探讨了Python的性能优化与调试技巧,涵盖profiling、caching、Cython等优化工具,以及pdb、logging、assert等调试方法。通过实战项目,如优化斐波那契数列计算和调试Web应用,帮助读者掌握这些技术,提升编程效率。附有进一步学习资源,助力读者深入学习。
|
11天前
|
数据采集 安全 BI
用Python编程基础提升工作效率
一、文件处理整明白了,少加两小时班 (敲暖气管子)领导让整理100个Excel表?手都干抽筋儿了?Python就跟铲雪车似的,哗哗给你整利索!
50 11
|
2月前
|
人工智能 Java 数据安全/隐私保护
[oeasy]python081_ai编程最佳实践_ai辅助编程_提出要求_解决问题
本文介绍了如何利用AI辅助编程解决实际问题,以猫屎咖啡的购买为例,逐步实现将购买斤数换算成人民币金额的功能。文章强调了与AI协作时的三个要点:1) 去除无关信息,聚焦目标;2) 将复杂任务拆解为小步骤,逐步完成;3) 巩固已有成果后再推进。最终代码实现了输入验证、单位转换和价格计算,并保留两位小数。总结指出,在AI时代,人类负责明确目标、拆分任务和确认结果,AI则负责生成代码、解释含义和提供优化建议,编程不会被取代,而是会更广泛地融入各领域。
103 28
|
2月前
|
机器学习/深度学习 数据可视化 TensorFlow
Python 高级编程与实战:深入理解数据科学与机器学习
本文深入探讨了Python在数据科学与机器学习中的应用,介绍了pandas、numpy、matplotlib等数据科学工具,以及scikit-learn、tensorflow、keras等机器学习库。通过实战项目,如数据可视化和鸢尾花数据集分类,帮助读者掌握这些技术。最后提供了进一步学习资源,助力提升Python编程技能。
|
2月前
|
Python
[oeasy]python074_ai辅助编程_水果程序_fruits_apple_banana_加法_python之禅
本文回顾了从模块导入变量和函数的方法,并通过一个求和程序实例,讲解了Python中输入处理、类型转换及异常处理的应用。重点分析了“明了胜于晦涩”(Explicit is better than implicit)的Python之禅理念,强调代码应清晰明确。最后总结了加法运算程序的实现过程,并预告后续内容将深入探讨变量类型的隐式与显式问题。附有相关资源链接供进一步学习。
54 4
|
2月前
|
Java API Docker
在线编程实现!如何在Java后端通过DockerClient操作Docker生成python环境
以上内容是一个简单的实现在Java后端中通过DockerClient操作Docker生成python环境并执行代码,最后销毁的案例全过程,也是实现一个简单的在线编程后端API的完整流程,你可以在此基础上添加额外的辅助功能,比如上传文件、编辑文件、查阅文件、自定义安装等功能。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
在线编程实现!如何在Java后端通过DockerClient操作Docker生成python环境
|
2月前
|
机器学习/深度学习 设计模式 API
Python 高级编程与实战:构建 RESTful API
本文深入探讨了使用 Python 构建 RESTful API 的方法,涵盖 Flask、Django REST Framework 和 FastAPI 三个主流框架。通过实战项目示例,详细讲解了如何处理 GET、POST 请求,并返回相应数据。学习这些技术将帮助你掌握构建高效、可靠的 Web API。
|
2月前
|
机器学习/深度学习 设计模式 测试技术
Python 高级编程与实战:构建自动化测试框架
本文深入探讨了Python中的自动化测试框架,包括unittest、pytest和nose2,并通过实战项目帮助读者掌握这些技术。文中详细介绍了各框架的基本用法和示例代码,助力开发者快速验证代码正确性,减少手动测试工作量。学习资源推荐包括Python官方文档及Real Python等网站。
|
2月前
|
机器学习/深度学习 设计模式 API
Python 高级编程与实战:构建微服务架构
本文深入探讨了 Python 中的微服务架构,介绍了 Flask、FastAPI 和 Nameko 三个常用框架,并通过实战项目帮助读者掌握这些技术。每个框架都提供了构建微服务的示例代码,包括简单的 API 接口实现。通过学习本文,读者将能够使用 Python 构建高效、独立的微服务。
|
2月前
|
消息中间件 分布式计算 并行计算
Python 高级编程与实战:构建分布式系统
本文深入探讨了 Python 中的分布式系统,介绍了 ZeroMQ、Celery 和 Dask 等工具的使用方法,并通过实战项目帮助读者掌握这些技术。ZeroMQ 是高性能异步消息库,支持多种通信模式;Celery 是分布式任务队列,支持异步任务执行;Dask 是并行计算库,适用于大规模数据处理。文章结合具体代码示例,帮助读者理解如何使用这些工具构建分布式系统。

热门文章

最新文章