Python练习-成绩管理系统

成绩管理系统实现了如下功能:
1、根据学号录入、修改、删除、查看相应分数。
2、按照ID查看所有数据。
3、根据分数高低排序查看所有数据。
4、向表中添加新的ID、姓名。
5、运行时系统首先检测是否存在指定文件,如果有则直接读取,没有则在指定文件夹创建。
6、只允许输入列出的整数,输入其他数据类型或者没有列出的数字会显示提示并重新进入选择。

具体代码如下:

import pandas as pd     # 用于处理表格数据
import os.path          # 用于检测文件是否存在
import openpyxl         # 用于创建表格


class Sys:
    
    if os.path.exists('D:/python/pythonProject/student_scores.xlsx'):   # 检测文件是否存在
        pass            # 如果存在就跳过
    else:
        wb = openpyxl.Workbook()
        wb.save('D:/python/pythonProject/student_scores.xlsx')          # 如果不存在就通过Workbook来创建
    data = pd.read_excel('D:/python/pythonProject/student_scores.xlsx')     # 读取表格中的数据并赋值给data

    def __init__(self):     # 定义初始化函数
        self.data = Sys.data    # 定义类变量,将类变量data赋值给实例化变量
        self.operation()        # 执行operation函数

    def save(self):             # 定义一个将frame导出到excel文件的函数
        self.data.to_excel('D:/python/pythonProject/student_scores.xlsx', index=False)  # index=False,不添加索引

    def entering(self):         # 定义一个录入成绩的函数
        stu_num = int(input("请输入学生的学号:"))
        # new_frame =  pd.DataFrame([[stu_num, pd.NaT, pd.NaT]], columns=["ID", "Name", "score"])
        # self.data = pd.concat([self.data, new_frame])
        # 上面两行是另一种实现方式,但是这种方式会产生重复的数据,即系统不管有没有这个学号,都会在末尾追加数据。
        stu_score = int(input("请输入{}的成绩:".format(self.data.iloc[stu_num-1, 1])))
        # iloc用于定位数据的位置,这里使用iloc读取学号为stu_num的学生姓名
        self.data.iat[stu_num-1, 2] = stu_score     # 使用iat函数定位,并将分数放在这个位置。
        self.save()

    def modify(self):   # 定义一个修改学生成绩的函数,其实和添加成绩是同一个实现方式。
        stu_num = int(input("请输入要修改成绩学生的学号:"))
        stu_score = int(input("请输入{}的成绩:".format(self.data.iloc[stu_num-1, 1])))
        self.data.iat[stu_num-1, 2] = stu_score
        self.save()

    def query(self):    # 定义一个根据学号查询成绩的函数
        stu_num = int(input("请输入要查询的学号:"))
        print("{}的成绩是{}".format(self.data.loc[stu_num-1, "Name"], self.data.loc[stu_num-1, "score"]))
        # 这里使用了loc来进行定位,loc使用行列标签定位,iloc使用行列位置定位

    def dlt(self):  # 定义一个只删除成绩,不删除学生信息的函数。
        stu_num = int(input("请输入要删除成绩的学号:"))
        self.data.iat[stu_num-1, 2] = pd.NaT    # 使用iat定位,并将pandas自带的空值NaT赋值给score。
        self.save()

    def browse(self):   # 定义一个浏览成绩的函数
        rank = self.data.sort_values(by='ID')   # 以ID值大小为表格排序
        print(rank)

    def rank(self):     # 定义一个按照成绩高低来排序的函数
        rank = self.data.sort_values(by='score')    # 以score值大小为表格排序,默认降序
        print(rank.iloc[::-1])      # 倒序输出

    def stu_entering(self):     # 定义一个添加学生的函数
        stu_num = int(input("请输入新学生的学号:"))
        stu_name = input("请输入新学生的姓名:")
        new_stu = pd.DataFrame([[stu_num, stu_name, pd.NaT]], columns=["ID", "Name", "score"])
        # 将新学生信息存储为dataframe格式,默认成绩为空,即pd.NaT
        self.data = pd.concat([self.data, new_stu])     # 在原有的dataframe(self.data)上扩展新的dataframe(new_stu)
        self.save()

    def operation(self):  # 定义一个流程控制函数
        while True:
            oper_num = input("1-录入成绩\t2-修改成绩\t3-查询成绩\t4-删除成绩\n5-查看所有\t6-查看排名\t7添加学生\t8-退出\n请选择您要进行的操作:")
            try:
                operation_select = int(oper_num)
                if operation_select == 1:
                    self.entering()
                elif operation_select == 2:
                    self.modify()
                elif operation_select == 3:
                    self.query()
                elif operation_select == 4:
                    self.dlt()
                elif operation_select == 5:
                    self.browse()
                elif operation_select == 6:
                    self.rank()
                elif operation_select == 7:
                    self.stu_entering()
                elif operation_select == 8:
                    print("欢迎再次使用^_^")
                    break
                else:
                    print("请输入列出的数字")
            except ValueError:
                print("只能输入数字来选择操作")


if __name__ == '__main__':
    Sys()

笔记:

#检测file是否存在
os.path.exists("file")	
#创建表格文件
wb = openpyxl.Workbook()
wb.save("file.xlsx")
#读取表格文件
data = pd.read_excel('file.xlsx')
#向表格写入数据
data.to_excel('')
#创建dataframe
new_frame =  pd.DataFrame([[stu_num, pd.NaT, pd.NaT]], columns=["ID", "Name", "score"])
#扩展dataframe
data = pd.concat([data, new_frame])
#根据行和列名定位
loc[stu_num-1, "score"]
#根据行列位置定位(以0开头)
iloc[stu_num-1, 1]
iat[stu_num-1, 1]
#对dataframe按某列排序
rank = data.sort_values(by='ID')
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python成绩管理系统大作业是一个学习和练习编程技巧的绝佳机会。该项目旨在使用Python编程语言开发一款简单但实用的成绩管理系统,以帮助学生和教师更好地管理和记录学生的成绩。 这个大作业可以分为以下几个重要的部分: 1. 学生信息管理:使用Python数据结构和算法来管理学生的基本信息,如学号、姓名、年龄等。可以实现添加学生、删除学生、修改学生信息等功能。 2. 成绩录入与统计:根据教师录入的成绩,使用Python的数学运算和逻辑判断来计算学生的平均成绩、最高成绩、最低成绩等统计数据,并将结果保存到文件中。 3. 成绩查询与分析:根据学生的学号或姓名,使用Python实现对学生成绩查询功能。可以根据学号或姓名快速找到学生,并显示其各科成绩以及总成绩。 4. 数据持久化:使用Python的文件读写操作,将学生信息和成绩数据保存到文件中,并能够从文件中读取数据进行操作。 5. 用户界面设计:使用Python的GUI库(如Tkinter)设计一个简单而直观的用户界面,使教师和学生可以方便地进行操作。 通过完成这个大作业,我们可以提高Python编程的实践能力,熟悉Python语法和常用的库函数的使用。同时,还可以锻炼数据结构和算法的设计与实现,培养解决问题的思维和团队合作能力。 总之,Python成绩管理系统大作业是一个实践和提高自己编程技能的项目,通过完成这个项目,我们可以深入了解Python语言的特性,并将所学知识应用到实际问题中。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值