Python使用Excel表格的学生成绩管理系统

代码附上:

"""
此项目使用 【pandas】Excel管理模块,【xlwings】Excel管理模块,【OS】系统命令模块
"""

import pandas as pd
import xlwings as xw
import os
id = []  # 定义学号列表
name = []  # 定义姓名列表
fenshu = []  # 定义分数列表
"""
使用OS模块判断文件是否存在,不存在就新建一个
"""
wenjian = os.path.exists('stuapp.xlsx')
if wenjian == False:
   app = xw.Book()
   app.save('./stuapp.xlsx')
   app.close()
else:
    print("读取文件成功!")
#定义menu函数作为菜单
def menu():
    print('='*20)
    print('学生成绩管理系统命令行最终版')
    print('1.添加学生成绩')
    print('2.删除学生成绩')
    print("3.查看所有学生成绩")
    print('4.通过学号搜索学生')
    print('5.修改学生信息')
    print("0.退出程序")
    print('=' * 20)
    xuanze = input("请选择:")
    if xuanze == '1':
        addstu()
    if xuanze == '0':
        exit()
    if xuanze == '3':
        allstr()
    if xuanze == '2':
        delstu()
    if xuanze == '4':
        search()
    if xuanze == '5':
        xiugai()
#定义读取函数
def read():
    liebiao = pd.read_excel('./stuapp.xlsx')    #使用pandas模块读取文件内容
    try:    #使用for循环读取进列表
        for i in liebiao['学号']:
            id.append(i)
        for i in liebiao['姓名']:
            name.append(i)
        for i in liebiao['分数']:
            fenshu.append(i)
    except: #如果列表内无索引(无内容)则跳过读取
        if KeyError:
            pass
#定义储存函数
def save():
    liebiao = pd.DataFrame()
    liebiao['学号'] = id  # 二元数据学号列展示id这个列表
    liebiao['姓名'] = name
    liebiao['分数'] = fenshu

    print(liebiao)  # 打印到屏幕上
    liebiao.to_excel('./stuapp.xlsx')   #通过pandas to_excel方法将列表文件储存到文件内
#定义展示所有列表函数
def allstr():
    liebiao = pd.DataFrame()


    liebiao['学号'] = id  # 二元数据学号列展示id这个列表
    liebiao['姓名'] = name
    liebiao['分数'] = fenshu
    print(liebiao)
#定义添加数据函数
def addstu():
    while True:  # 使用while循环无限循环
        liebiao = pd.DataFrame()  # 使用pd模块定义二元数据


        a1 = input("请输入学号:")  # 用户输入
        try:
            int(a1)
        except ValueError:
                print('学号必须为数字!')
                continue
        if int(a1) in id:
            print('该学号已经录入信息!')
            continue
        else:
            a2 = input("请输入姓名:")
            a3 = input("请输入分数:")
            
            id.append(int(a1))  # 把用户输入的内容添加进相对应的列表
            name.append(a2)
            fenshu.append(a3)

            save()

            xuanze = input("是否继续输入?(y/n):")
            if xuanze == 'y':
                continue
            else:

                break

            
#定义删除函数
def delstu():
    while True:
        print(id)
        allstr()

        delid = int(input("请输入要删除的学生的学号:"))


        try:
            aaa = id.index(delid)
            int(aaa)
            del id[aaa]
            del name[aaa]
            del fenshu[aaa]
        except ValueError:
            print('未找到该学生!')

        xuanze = input("继续or退出?[y/n]:")
        if xuanze == 'n':
            allstr()
            save()
            break

        if xuanze == 'y':
            continue
#定义搜索函数
def search():
    while True:
        try:
            search1 = int(input("请输入学号:"))

            a = id.index(search1)
            int(a)
            jieguo = {'学号':id[a],'姓名':name[a],'分数':fenshu[a]}
            print(jieguo)
        except ValueError:
            print('未找到该学生')



        xuanze = input("是否继续?[y/n]:")
        if xuanze == 'y':
            continue
        if xuanze == 'n':
            break
#定义修改函数
def xiugai():
    while 1:
        try:
            a = int(input('请输入要修改的学生学号:'))
            b = id.index(a)
        except ValueError:
            print('未找到该学生信息')
            break
        int(b)
        c = {'学号': id[b], '姓名': name[b], '分数': fenshu[b]}
        d = id.index(a)

        print(c)
        xiugaiid = input("请输入修改后的学号:")
       
        if int(xiugaiid) == id[int(d)]:

            try:
                int(xiugaiid)
                
            except ValueError:
                print('请输入数字!')
                break
            xiugainame = input("请输入修改后的名字:")
            xiugaifenshu = input('请输入修改后的分数:')
            id[b] = int(xiugaiid)
            name[b] = xiugainame
            fenshu[b] = xiugaifenshu
            d = {'学号': id[b], '姓名': name[b], '分数': fenshu[b]}
            print(d)
            save()
            xuanze = input("是否继续修改?【y/n】:")
            if xuanze == 'y':
                continue
            else:
                break
        if int(xiugaiid) in id:
            print('该学号已经录入信息!')
            break

   
#总程序main
def main():
    read()
    while True:
        menu()
if __name__ == '__main__':
    main()

  • 2
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
一、特色 本作品采用EXCEL 公式+VBA制作,既可根据你平时使用EXCEL的习惯和方式操作充分发挥EXCEL的功能,又能利用本作品提高效率。 ※※※※二、主要功能 1、在原始成绩表自动按你要求的统计科目生成总分、平均分、班级排名、年级排名等。 2、查询:查询条件多样,可按姓名查询、按班级查询(分班);按某学科(含总分)某分数段查询;按班内名次(年级名次)段查询(如某班前XX名、年级前XX-XX名)等,各种查询条件还可自由组合。对查询结果,可按某关键字排序后显示,如按班级排名升序可组合出某班全部或班前XX名、年级前XX名排名等,按年级排名升序可组合出年级前XX名排名或全部排名等。 3、统计:根据班级和科目(含总体)按统计范围自动实时生成各项指标(参考人数、平均分、及格人数、及格率、优生人数、优生率、差生人数、差生率等)、各分数段人数统计、年级前XX名在各班分布等。 4、成绩册和成绩条:实时自动按班生成成绩册和成绩条。 ※※※※三、操作指南   第一步:在总输入、导入、复制粘贴或在记录单逐条录入原始成绩(第一行为如下形式) 学号 ∣ 数学 ∣ 总分 ∣ 学号 ∣ 语文 ∣ 班级 ∣ 英语 ∣ 姓名 ∣ 政治 ∣ 历史 ∣ 物理 ∣ 化学 ∣ …… "  1、其各列位置不固定   2、班级列必须包含   3、可以任意增加删除科目   4、可以任意增加删除辅助列如:学号、年级、座位号等"   第二步 :设置 "  1、打开设置工作进行设置   2、包括考试名称和统计科目的设置   3、具体设置方法内的批注已经说明"   第三步:点击控制条上的各个按钮进行相应统计 其,分班成绩册和成绩单、统计分别以VBA和公式两种方式制作,这两种方式各有特点,供你选择:公式方式的优点是当条件变化(如所选班级、科目变化)时显示结果随之实时变化,除非公式被破坏或者刚从其它册转入本功能你才需要重新点击按钮;VBA方式每次改变条件后必须点击相应按钮才能刷新结果,但对结果你可随意进行各种操作。如果你觉得窗体有可能遮住结果,窗体可移动,可关闭,以便在EXCEL按你熟悉的方式操作。另总还提供了按班级排序、填入总分、平均分、计算班级排名、年级排名、分数超限检查等多种自动化功能。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值