Python编程基础:实验7——文件和数据格式化

简介: 巩固Python文件操作相关基础知识,熟练的掌握文件操作至关重要。

一、前言

在本期实验中我们将利用之前学习的相关Python文件操作来进行题目代码练习,巩固知识。

二、我的环境

  • 电脑系统:Windows 11
  • 语言版本:Python 3.10.4
  • 编译器:VSCode

三、实验目的与要求

  1. 熟练掌握文件的打开、关闭和读写
  2. 理解数据组织的维度、掌握一维数据和二维数据的处理方法
  3. 掌握采用CSV格式对一二维数据文件进行读写的方法

四、实验任务

1、程序填空

【填空12-1】编写程序,根据用户输入的星座名称,输出此星座的出生日期范围及对应的星座符号。程序不完整,请完善代码。

星座及出生日期范围已存于文件SunSign.csv中,文件内容如下图所示。首先读入CSV文件中数据到一个列表中,然后获得用户输入,则输出此星座信息,直至用户输入“exit”程序结束。

image-20221012094755871.png

image-20221012095844144.png

fo=open(".\填空题\SunSign.csv", "r", encoding="GB18030")
ls= []
forlineinfo:
line=line.replace("\n","")
ls.append(line.split(","))
fo.close()
whileTrue:
InputStr=input()
InputStr.strip()
flag=FalseifInputStr=='exit':
breakforlineinls:
ifInputStr==line[0]:
print("{}座的生日位于{}-{}之间".format(chr(eval(line[3])), line[1], line[2]))
flag=Trueifflag==False:
print("输入星座名称有误!")

它运行的结果是:

白羊座♈座的生日位于321-419之间天蝎座♏座的生日位于1024-1122之间水瓶座♒座的生日位于120-218之间exit

【填空12-2】编写程序,统计并输出传感器采集数据中光照部分的最大值、最小值和平均值,所有值保留小数点后2位。程序不完整,请完善代码。

已知传感器采集数据文件为sensor-data.txt,如下图所示,其中每行是一个整体数据.分别包括"日期、时间、温度、湿度、光照和电压"等6个读数,光照数据处于第5列,在列表中表示光照数据时下标应为4。

image-20221012100521797.png

f=open(".\填空题\sensor-data.txt", "r")
avg, cnt=0, 0maxv, minv=0, 9999forlineinf:
ls=line.split()
cnt+=1val=eval(ls[4])
avg+=valifval>maxv:
maxv=valifval<minv:
minv=valprint("最大值、最小值、平均值分别是:{:.2f},{:.2f},{:.2f}".format(maxv, minv, avg/cnt))
f.close()

它运行的结果是:

最大值、最小值、平均值分别是:47.08,45.08,46.08

2、程序编程

【编程12-1】文件smartphone.txt 存放着部分公司手机年销量数据,每行为每家公司连续4年的销量数据,数据项间以制表符作为分隔,文件内容如下图所示。

编写程序,显示各公司年销量是否快速增长的情况(本题设年销量增长率均超过30%为快速增长),程序运行结果如下图所示。现给出部分程序代码,请根据题目要求进行编程。

image-20221012100649054.png

rate=0.3defisBigGrowth(L, rate):
foriinrange(0, len(L)-1):
yearGrowth= (L[i+1]-L[i])/L[i]
if(yearGrowth<rate):
returnFalsereturnTrueprint("手机公司  是否快速增长?")
data= []
withopen(".\编程题\smartPhone.txt",encoding="utf-8") asf:
data=f.readlines()
deldata[0]
forcompanyindata:
company=company.split()
foriinrange(1, len(company)):
company[i] =float(company[i])
ifisBigGrowth(company[1:], 30/100):
print("%s\t\t%s"% (company[0], "快速"))
else:
print("%s\t\t%s"% (company[0], "否"))

它运行的结果是:

手机公司是否快速增长?SamsungAppleHuaweiOPPO快速Vivo快速ZTELGLenovoXiaomi

五、最后我想说

本期有关文件和数据格式化的实验就到这里结束了,如果还对文件相关操作不熟悉的朋友可以去看看我前面更新的有关文件操作知识的博客。

Python编程基础:文件基础

另外,在本期实验中,如果出现编码报错,可以修改一下编码进行解决,如果出现无法找到文件的错误,可以尝试一下相对路径,看看文件是否跟代码放在同一文件目录下,或者使用绝对路径尝试一下。

目录
相关文章
|
3天前
|
Shell Python
Python Stock guess_indicators_daily_job.py文件的调整
Python Stock guess_indicators_daily_job.py文件的调整
12 1
|
3天前
|
XML 前端开发 数据格式
BeautifulSoup 是一个 Python 库,用于从 HTML 和 XML 文件中提取数据
BeautifulSoup 是 Python 的一个库,用于解析 HTML 和 XML 文件,即使在格式不规范的情况下也能有效工作。通过创建 BeautifulSoup 对象并使用方法如 find_all 和 get,可以方便地提取和查找文档中的信息。以下是一段示例代码,展示如何安装库、解析 HTML 数据以及打印段落、链接和特定类名的元素。BeautifulSoup 还支持更复杂的查询和文档修改功能。
11 1
|
1天前
|
Python
在Python中,利用`os模块`的`path.exists()`函数可判断文件是否存
在Python中,利用`os模块`的`path.exists()`函数可判断文件是否存在,该函数对路径进行检查,存在则返回True,不存在则返回False。示例代码展示了如何检查&#39;example.txt&#39;文件是否存在并相应打印消息。此外,`os.path.isfile()`用于确认路径是否为文件,仅当是文件时返回True,否则返回False,同样配以示例说明其用法。
8 2
|
4天前
|
JSON 数据格式 开发者
pip和requests在Python编程中各自扮演着不同的角色
`pip`是Python的包管理器,用于安装、升级和管理PyPI上的包;`requests`是一个HTTP库,简化了HTTP通信,支持各种HTTP请求类型及数据交互。两者在Python环境中分别负责包管理和网络请求。
19 5
|
4天前
|
数据采集 NoSQL 中间件
python-scrapy框架(四)settings.py文件的用法详解实例
python-scrapy框架(四)settings.py文件的用法详解实例
9 0
|
4天前
|
存储 数据采集 数据库
python-scrapy框架(三)Pipeline文件的用法讲解
python-scrapy框架(三)Pipeline文件的用法讲解
7 0
|
4天前
|
存储 JSON 数据挖掘
python序列化和结构化数据详解
python序列化和结构化数据详解
12 0
|
5天前
|
数据采集 数据可视化 数据挖掘
Python 与 PySpark数据分析实战指南:解锁数据洞见
Python 与 PySpark数据分析实战指南:解锁数据洞见
|
5天前
|
数据采集 数据处理 开发者
Python 中的数据处理技巧:高效数据操作的艺术
Python 在数据处理方面表现卓越,为开发者提供了丰富的工具和库以简化数据操作。在本文中,我们将探讨 Python 中数据处理的一些技巧,包括数据清洗、数据转换以及优化数据操作的最佳实践。通过掌握这些技巧,您可以在 Python 中更加高效地处理和分析数据。
|
6天前
|
机器学习/深度学习 自然语言处理 算法
Python遗传算法GA对长短期记忆LSTM深度学习模型超参数调优分析司机数据|附数据代码
Python遗传算法GA对长短期记忆LSTM深度学习模型超参数调优分析司机数据|附数据代码