当前位置: 首页 > news >正文

文件中的成绩统计分析----Python

文件中的成绩统计分析

描述

现在一个包含若干学生学习成绩的文件,每位同学有4 门课程的成绩,按要求完成以下任务。

文件中每行数据格式如下:

0121801101266,刘雯,92,73,72,64

0121801101077,张佳喜,81,97,61,98

0121801101531,佘玉龙,73,89,81,93

读取附件文件中的数据,对数据进行处理,计算每个同学 4 门课程成绩的平均成绩,将平均成绩置于课程成绩后一列,按照平均分升序排序后输出。‪‪‪‪‪‪‪‪‪‪‪‪‪‪‪‪‪‪‫‪‪‪‪‪‪‪‪

 根据以下输入要求,输出相应的数据:‪‪‪‪‪‪‪‪‪‪‪‪‪‪‪‪‪‪‫‪‪‪‪‪‪‪‪

1.输出平均分最高的同学名字与平均成绩,名字与分数间用一个空格分隔;

2.‪‪‪‪‪‪‪‪‪‪‪‪‪‪‪‪‪‪‫‪‪‪‪‪‪输出平均分最低的同学名字与平均成绩,名字与分数间用一个空格分隔;

3.输出按平均分从低到高的排序数据,要求每个数据之间以空格间隔,每行结尾无空格。

4.‪‪‪‪‪‪‪‪‪‪‪‪‪‪‪‪‪‪‫‪‪‪‪‪‪‪输入一个学生的名字,输出该名同学所在行的的全部数据,各数据项间用一个空格分隔,结尾无空格;‪‪‪‪‪‪‪‪‪‪‪‪‪‪‪‪‪‪‫‪‪‪‪‪‪‪‪

5.如输入的姓名在文件中不存在,输出  '姓名不存在'

# 读取文件,将读取到的字符串,按逗号分割,形成一个新的列表并返回
def read(filename):
    with open(filename, 'r', encoding='utf-8') as fr:
        score_lst = []
        for line in fr:
            score_lst.append(line.strip().split(','))  # line.strip()去掉换行符,去掉换行符后变成了字符串
    return score_lst


# 计算平均数并添加到列表中,返回包含平均数的新列表
def score_add_avg(score_lst):
    score_avg_lst = []
    for x in score_lst:
        avg = sum(map(int, x[2:])) / len(x[2:])
        x.append(avg)
        score_avg_lst.append(x)  # 将加了平均成绩的0列表加到新的列表
    return score_avg_lst

# 将列表按照平均数的大小从低到高排序
def sort_score(sort_lst):
    sort_lst.sort(key=lambda x: x[6])
    return sort_lst


# 3.输出按平均分从低到高的排序数据,要求每个数据之间以空格间隔,每行结尾无空格。
def output_all(sort_lst):
    for score in sort_lst:
        print(*score)  # *号进行解包


# 4.输入一个学生的名字,输出该名同学所在行的的全部数据,各数据项间用一个空格分隔,结尾无空格;
def query_studeng(sort_lst, stu_name):
    for line in sort_lst:
        if stu_name in line:
            return line
    else:
        return None


score = read('6.5 score.txt')
score_with_avg = score_add_avg(score)
sorted_score = sort_score(score_with_avg)
print(sorted_score)
# 1.输出平均分最高的同学名字与平均成绩,名字与分数间用一个空格分隔;
print(sorted_score[-1][1], sorted_score[-1][6])
# 2.输出平均分最低的同学名字与平均成绩,名字与分数间用一个空格分隔;
print(sorted_score[0][1], sorted_score[0][6])
output_all(sorted_score)
student_name = input()
info = query_studeng(sorted_score, student_name)
if info:
    print(*info)
else:  # 5.如输入的姓名在文件中不存在,输出  '姓名不存在'
    print('姓名是不存在的')

 

相关文章:

  • 甘肃省建设厅网站资质升级公示/全网营销渠道
  • 手机版网站如何做/推广普通话手抄报句子
  • 网页和网站区别是什么/湖北百度推广电话
  • 做网站设计好的公司/独立站谷歌seo
  • 建设企业网站需要什么呢/快速提升网站关键词排名
  • 杂志社网站建设方案/百度广告推广怎么做
  • Python使用pandas导入xlsx格式的excel文件内容
  • RV1126笔记三:人脸识别方案<一>
  • docker-network认识
  • 电磁波的达朗贝尔方程 工程电磁场P25
  • Flink Process Function
  • 【ChangeFormer】工程代码复现
  • ElasticSearch——刷盘原理流程
  • 【Kotlin 协程】Flow 异步流 ③ ( 冷流 | 流被收集时运行 | 流的连续性 )
  • 新能源汽车市场渗透率不断提高,锂电设备需求空间较大
  • Windows系统增强优化工具
  • 【ESP32+freeRTOS学习笔记-(三)任务】
  • 单片机——数码管