草庐IT

学生信息管理系统 python实现(含全部代码)

CodeProNotes 2023-08-14 原文

学生信息管理系统笔记python

一、需求分析

应具备的功能:

  1. 添加学生信息及成绩信息
  2. 将学生信息保存在文件中
  3. 修改和删除学生信息
  4. 查询学生信息
  5. 根据学生成绩进行排序
  6. 统计学生总分

二、系统设计

学生信息管理系统的7大模块

  1. 录入学生信息模块

  2. 查找学生信息

  3. 删除学生信息

  4. 修改学生信息

  5. 学生成绩排名

  6. 统计学生总人数

  7. 显示全部学生信息

四、系统实现

main()

menu()

search()

delete()

modify()

insert()

total()

show()

sort()

五、打包项目生存exe文件

安装第三方包

pip install PyInstaller

打开命令行,打包exe

pyinstaller -F “D:\Program Files (x86)\pycharm\PythonProject\studentsys\stusystem.py”

图片中标红位置为exe程序存储位置。

图片中标红位置为exe程序存储位置。

六、代码实现

import os.path

filename = 'students.txt'


def main():
    while True:
        menu()
        choice = int(input('请选择功能'))
        if choice in [0, 1, 2, 3, 4, 5, 6, 7]:
            if choice == 0:
                answer = input('您确定退出系统吗?y/n')
                if answer == 'y' or answer == 'Y':
                    print("欢迎您的使用!!")
                    break
                else:
                    continue
            elif choice == 1:
                insert()
            elif choice == 2:
                search()
            elif choice == 3:
                delete()
            elif choice == 4:
                modify()
            elif choice == 5:
                sort()
            elif choice == 6:
                total()
            elif choice == 7:
                show()
        input()


def menu():
    print('==================学生信息管理系统==============')
    print('===============功能菜单==================')
    print('\t\t\t1. 录入学生信息')
    print('\t\t\t2. 查找学生信息')
    print('\t\t\t3. 删除学生信息')
    print('\t\t\t4. 修改学生信息')
    print('\t\t\t5. 对学生成绩进行排序')
    print('\t\t\t6. 统计学生总人数')
    print('\t\t\t7. 显示所有学生信息')
    print('\t\t\t0. 退出程序')
    print('======================================')


def insert():
    student_list = []
    while True:
        id = input("请输入ID:")
        if not id:
            break
        name = input("请输入姓名:")
        if not name:
            break
        try:
            english = int(input("请输入英语成绩:"))
            python = int(input("请输入python成绩:"))
            java = int(input("请输入Java成绩:"))
        except:
            print("输入无效,请重新输入")
        # 将录入的学生信息保存在字典中
        student = {'id': id, 'name': name, 'english': english, 'python': python, 'java': java}
        # 将学生信息添加到列表中
        student_list.append(student)
        answer = input("是否继续添加y/n?")
        if answer == 'y':
            continue
        else:
            break
    # 调用save函数保存信息
    save(student_list)
    print("学生信息保存成功")


def save(lst):
    try:
        stu_txt = open(filename, 'a', encoding='utf-8')
    except:
        stu_txt = open(filename, 'w', encoding='utf-8')
    for item in lst:
        stu_txt.write(str(item) + '\n')
    stu_txt.close()


def search():
    student_query = []
    while True:
        id = ''
        name = ''
        if os.path.exists(filename):
            mode = input("按ID查找请按1,按姓名查找请按2:")
            if mode == '1':
                id = input("请输入学生ID:")
            elif mode == '2':
                name = input("请输入学生新明:")
            else:
                print("输入有误,请重新输入")
                search()
            with open(filename, 'r', encoding='utf-8') as file:
                student = file.readlines()
                for item in student:
                    d = dict(eval(item))
                    if id != '':
                        if d['id'] == id:
                            student_query.append(d)
                    elif name != '':
                        if d['name'] == name:
                            student_query.append(d)
            show_query(student_query)
            # 清空列表
            student_query.clear()
            answer = input("是否继续查询?y/n")
            if answer == 'y':
                continue
            else:
                break
        else:
            print("无学生信息")
            return


def show_query(lst):
    if len(lst) == 0:
        print("无相关信息")
        return
    # 定义标题显示格式
    format_title = '{:^6}\t{:^12}\t{:^8}\t{:^10}\t{:^10}\t{:^8}'
    print(format_title.format('ID', '姓名', '英语成绩', 'python成绩', 'Java成绩', '总成绩'))
    # 定义内容显示格式
    format_data = '{:^6}\t{:^12}\t{:^8}\t{:^10}\t{:^10}\t{:^8}'
    for item in lst:
        print(format_data.format(item.get('id'),
                                 item.get('name'),
                                 item.get('english'),
                                 item.get('english'),
                                 item.get('java'),
                                 int( item.get('english')) + int( item.get('english')) + int( item.get('java'))
                                 ))


def delete():
    while True:
        student_id = input("请输入删除学生的ID:")
        if student_id != '':
            if os.path.exists(filename):
                with open(filename,'r',encoding='utf-8') as file:
                    student_old = file.readlines()
            else:
                student_old = []
            flag = False
            if student_old:  # 空列表等于 False,非空列表等于True
                with open(filename,'w',encoding='utf-8') as wfile:
                    # 只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除
                    d = {}
                    for item in student_old:
                        d = dict(eval(item))  # 将字符串转换为字典
                        if d['id'] != student_id:
                            wfile.write(str(d)+'\n')
                        else:
                            flag = True
                    if flag:
                        print(f'id为{student_id}的学生信息已被删除')
                    else:
                        print(f'没有找到学生ID为{student_id}的学生')
            else:
                print("无学生信息")
                break
            show()
            answer = input("是否继续删除?y/n")
            if answer == 'y':
                continue
            else:
                break


def modify():
    show()
    if os.path.exists(filename):
        with open(filename, 'r', encoding='utf-8') as file:
            student_old = file.readlines()
    else:
        return
    student_id = input("请输入修改学生的ID:")
    with open(filename, 'w', encoding='utf-8') as wfile:
        for item in student_old:
            d = {}
            d = dict(eval(item))
            if d['id'] == student_id:
                print("已经找到学生信息,请修改相关信息")
                while True:
                    try:
                        d['name'] = input("请输入姓名")
                        d['english'] = input("请输入英语成绩")
                        d['python'] = input("请输入python成绩")
                        d['java'] = input("请输入Java成绩")
                    except:
                        print("输入有误,请重新输入")
                    else:
                        break
                    wfile.write(str(d) + '\n')
                    print("修改成功")
            else:
                wfile.write(str(d)+'\n')
            answer = input("是否继续修改其他学生信息?y/n")
            if answer == 'y':
                modify()
            else:
                return


def sort():
    show()
    if os.path.exists(filename):
        with open(filename, 'r', encoding= 'utf-8') as file:
            students = file.readlines()
        students_new = []
        for item in students:
            d = dict(eval(item))
            students_new.append(d)
    else:
        return

    # 排序方式
    asc_or_desc = input("请选择升序 0 还是降序 1?")
    if asc_or_desc == '0':
        asc_or_desc_bool = False
    elif asc_or_desc == '1':
        asc_or_desc_bool = True
    else:
        print("输入有误,请重新输入")
        sort()
    mode = input("请选择排序方式(1.英语 2.python 3.Java 4.总成绩):")
    if mode == '1':
        students_new.sort(key=lambda x : int(x['english']), reverse=asc_or_desc_bool)
        # x 代表列表students_new中的项
    elif mode == '2':
        students_new.sort(key=lambda x: int(x['python']), reverse=asc_or_desc_bool)
    elif mode == '3':
        students_new.sort(key=lambda x: int(x['java']), reverse=asc_or_desc_bool)
    elif mode == '4':
        students_new.sort(key=lambda x: int(x['english']) + int(x['python']) + int(x['java']), reverse=asc_or_desc_bool)
    else:
        print("输入有误,请重新输入")
    show_query(students_new)


def total():
    if os.path.exists(filename):
        with open(filename, 'r', encoding='utf-8') as file:
            students = file.readlines()
            if students:
                print(f"总共有{len(students)}名学生")
            else:
                print("无学生信息")
    else:
        print("无学生信息")


def show():
    student_query = []
    if os.path.exists(filename):
        with open(filename, 'r', encoding='utf-8') as file:
            student = file.readlines()
            for item in student:
                d = dict(eval(item))
                student_query.append(d)
        show_query(student_query)
        # 清空列表
        student_query.clear()
    else:
        print("无学生信息")
        return


if __name__ == '__main__':
    main()

有关学生信息管理系统 python实现(含全部代码)的更多相关文章

  1. ruby - i18n Assets 管理/翻译 UI - 2

    我正在使用i18n从头开始​​构建一个多语言网络应用程序,虽然我自己可以处理一大堆yml文件,但我说的语言(非常)有限,最终我想寻求外部帮助帮助。我想知道这里是否有人在使用UI插件/gem(与django上的django-rosetta不同)来处理多个翻译器,其中一些翻译器不愿意或无法处理存储库中的100多个文件,处理语言数据。谢谢&问候,安德拉斯(如果您已经在ruby​​onrails-talk上遇到了这个问题,我们深表歉意) 最佳答案 有一个rails3branchofthetolkgem在github上。您可以通过在Gemfi

  2. python - 如何使用 Ruby 或 Python 创建一系列高音调和低音调的蜂鸣声? - 2

    关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。

  3. ruby-on-rails - Rails 常用字符串(用于通知和错误信息等) - 2

    大约一年前,我决定确保每个包含非唯一文本的Flash通知都将从模块中的方法中获取文本。我这样做的最初原因是为了避免一遍又一遍地输入相同的字符串。如果我想更改措辞,我可以在一个地方轻松完成,而且一遍又一遍地重复同一件事而出现拼写错误的可能性也会降低。我最终得到的是这样的:moduleMessagesdefformat_error_messages(errors)errors.map{|attribute,message|"Error:#{attribute.to_s.titleize}#{message}."}enddeferror_message_could_not_find(obje

  4. ruby - 如何在 buildr 项目中使用 Ruby 代码? - 2

    如何在buildr项目中使用Ruby?我在很多不同的项目中使用过Ruby、JRuby、Java和Clojure。我目前正在使用我的标准Ruby开发一个模拟应用程序,我想尝试使用Clojure后端(我确实喜欢功能代码)以及JRubygui和测试套件。我还可以看到在未来的不同项目中使用Scala作为后端。我想我要为我的项目尝试一下buildr(http://buildr.apache.org/),但我注意到buildr似乎没有设置为在项目中使用JRuby代码本身!这看起来有点傻,因为该工具旨在统一通用的JVM语言并且是在ruby中构建的。除了将输出的jar包含在一个独特的、仅限ruby​​

  5. ruby - 解析 RDFa、微数据等的最佳方式是什么,使用统一的模式/词汇(例如 schema.org)存储和显示信息 - 2

    我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i

  6. ruby-on-rails - Rails 源代码 : initialize hash in a weird way? - 2

    在rails源中:https://github.com/rails/rails/blob/master/activesupport/lib/active_support/lazy_load_hooks.rb可以看到以下内容@load_hooks=Hash.new{|h,k|h[k]=[]}在IRB中,它只是初始化一个空哈希。和做有什么区别@load_hooks=Hash.new 最佳答案 查看rubydocumentationforHashnew→new_hashclicktotogglesourcenew(obj)→new_has

  7. ruby - 如何根据特征实现 FactoryGirl 的条件行为 - 2

    我有一个用户工厂。我希望默认情况下确认用户。但是鉴于unconfirmed特征,我不希望它们被确认。虽然我有一个基于实现细节而不是抽象的工作实现,但我想知道如何正确地做到这一点。factory:userdoafter(:create)do|user,evaluator|#unwantedimplementationdetailshereunlessFactoryGirl.factories[:user].defined_traits.map(&:name).include?(:unconfirmed)user.confirm!endendtrait:unconfirmeddoenden

  8. ruby-on-rails - 浏览 Ruby 源代码 - 2

    我的主要目标是能够完全理解我正在使用的库/gem。我尝试在Github上从头到尾阅读源代码,但这真的很难。我认为更有趣、更温和的踏脚石就是在使用时阅读每个库/gem方法的源代码。例如,我想知道RubyonRails中的redirect_to方法是如何工作的:如何查找redirect_to方法的源代码?我知道在pry中我可以执行类似show-methodmethod的操作,但我如何才能对Rails框架中的方法执行此操作?您对我如何更好地理解Gem及其API有什么建议吗?仅仅阅读源代码似乎真的很难,尤其是对于框架。谢谢! 最佳答案 Ru

  9. ruby - 模块嵌套代码风格偏好 - 2

    我的假设是moduleAmoduleBendend和moduleA::Bend是一样的。我能够从thisblog找到解决方案,thisSOthread和andthisSOthread.为什么以及什么时候应该更喜欢紧凑语法A::B而不是另一个,因为它显然有一个缺点?我有一种直觉,它可能与性能有关,因为在更多命名空间中查找常量需要更多计算。但是我无法通过对普通类进行基准测试来验证这一点。 最佳答案 这两种写作方法经常被混淆。首先要说的是,据我所知,没有可衡量的性能差异。(在下面的书面示例中不断查找)最明显的区别,可能也是最著名的,是你的

  10. ruby - 寻找通过阅读代码确定编程语言的ruby gem? - 2

    几个月前,我读了一篇关于ruby​​gem的博客文章,它可以通过阅读代码本身来确定编程语言。对于我的生活,我不记得博客或gem的名称。谷歌搜索“ruby编程语言猜测”及其变体也无济于事。有人碰巧知道相关gem的名称吗? 最佳答案 是这个吗:http://github.com/chrislo/sourceclassifier/tree/master 关于ruby-寻找通过阅读代码确定编程语言的rubygem?,我们在StackOverflow上找到一个类似的问题:

随机推荐