各位用户为了找寻关于Python代码可以有多简洁,看看它如何实现数组求极值的资料费劲了很多周折。这里教程网为您整理了关于Python代码可以有多简洁,看看它如何实现数组求极值的相关资料,仅供查阅,以下为您介绍关于Python代码可以有多简洁,看看它如何实现数组求极值的详细内容

背景

Python 最大的优势是不需编译,而且代码简洁。我初学 Python 时,被它的简洁震惊到了,尤其是文件操作和数组操作,只需要一行代码搞定文件读入,相同功能, Java 的 IO 操作基本上是十行代码量。所以,偶尔也会用 Python 做一些小事情。

今天来整理一个 Python 的练习题,需求描述如下:

程序一: 接收用户输入的名字和成绩,成绩是1-100 间、最多两位小数。

按Q结束输入,并将合法输入的数据写入到一个文件。

程序二:读取程序一输出的文件,然后对成绩计算平均值,并输出最高分和最低分值及姓名。

实现分析

本例用到的知识点:

文件操作,需要 try-except-finally ,处理文件异常; 判断成绩的正则:^[0-9]{1,2}(.[0-9]{1,2})?$ ,成绩可以是小数点后两位小数; while 循环条件, Python 的逻辑运算是 and / or / not 等关键字,而不是逻辑操作符号; 使用 pd.read_csv 将 CVS 文件转换成 DataFrame 数据集; 使用 DataFrame 的 max 、min、avg 、idmax、idmin 等函数完成计算操作。

成绩信息收集

编写一个 score_writer.py 脚本文件,内容如下:

import re 

 

try: 

    # define file reader 

    f1 = open('E:/score.log','w',encoding='utf-8') 

    f1.write('name,scorern') 

    # 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+'rn') 

        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 后计算最值的索引小标后取名字列对应的元素就能输出最值的姓名了。

换一个不存在的文件路径,程序捕获异常:

编程启示录

Python 读写文件真是简洁呀,两行代码搞定,而 Java 要写几十行,真是两个极端。

想起前两天看到一个语言对比图: