diyanpython 2020-11-12
背景
Python 最大的优势是不需编译,而且代码简洁。我初学 Python 时,被它的简洁震惊到了,尤其是文件操作和数组操作,只需要一行代码搞定文件读入,相同功能, Java 的 IO 操作基本上是十行代码量。所以,偶尔也会用 Python 做一些小事情。
今天来整理一个 Python 的练习题,需求描述如下:
按Q结束输入,并将合法输入的数据写入到一个文件。
实现分析
本例用到的知识点:
成绩信息收集
编写一个 score_writer.py 脚本文件,内容如下:
import re try: # define file reader f1 = open('E:/score.log','w',encoding='utf-8') f1.write('name,score\r\n') # a pattern check score input pattern = "^[0-9]{1,2}(\.[0-9]{1,2})?$" print('请输入姓名和考试成绩,按 Q 结束,成绩范围 [1-100],最多允许两位小数。') # receive name name = input("姓名:") while name != 'Q' and name != 'q' : score = input("成绩:").strip() while re.match(pattern,score)==None and score != '100': score = input("成绩不合法,请重新输入:").strip() print(name,':',score) f1.write(name+','+score+'\r\n') name = input("姓名:") print('输入结束,存储数据') except IOError: print("操作异常") finally: f1.close()
运行结果:
成绩数据计算
编写一个 score_reader.py 脚本文件,内容如下:
from pandas import DataFrame import pandas as pd # array to load score try: # define file reader data = pd.read_csv('E:/score.log') print(data) print('平均值',data['score'].mean(axis = 0)) print(data['name'][data['score'].idxmax()],' 分数最高:',data['score'].max(axis = 0)) print(data['name'][data['score'].idxmin()],' 分数最低:',data['score'].min(axis = 0)) except IOError: print("文件不存在")
由于存储成的是 CVS 文件,标题是 name,scroe ,转换成 DataFrame 后计算最值的索引小标后取名字列对应的元素就能输出最值的姓名了。
换一个不存在的文件路径,程序捕获异常:
编程启示录