【python入门】day20:学生信息管理系统CRUD,排序模块和项目打包中的业务流程、具体实现

news2024/9/22 7:30:39

CRUD,每个程序员都必须掌握的

录入C create

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

def save(lst):#保存信息
    try:												#保存成绩时有可能出错,所以使用try-except
        stu_txt=open(filename,'a',encoding='utf-8')
        #filename是个变量,所以不用写单引号
        #文件以追加模式打开
        #怕中文乱码,所以加上encoding='utf-8'
    except:#出错:没有该文件的话就以写入的方式来打开
        stu_txt=open(filename,'w',encoding='utf-8')
    for item in lst:									#可迭代对象,逐个写入
        stu_txt.write(str(item)+'\n')					#保存到文本文件,要转换成str类型
    stu_txt.close()										#使用完要关闭资源
def insert():
    student_list=[]
    while True:
        id = int(input("请输入学号如10101"))
        if not id:
            break
        try:
            chinese=int (input("请输入语文成绩"))
            java= int (input("请输入java成绩"))
            python=int (input("请输入python成绩"))
        except:
            print('成绩输入无效,请输入整数')
            continue
        student={'id':id,'name':name,'chinese':chinese,'java':java,'python':python}		#建立字典,有点像结构体
        student_list.append(student)
        answer=input('是否需要继续输入\n')
        if answer=='y' or answer=='Y':
            continue
        else:
            break
        save(student_list)
        print("录入完毕!!")

删除D delete

在这里插入图片描述
在这里插入图片描述

def delete():											#删除学生信息
    while True:
        student_id=input('请输入要删除的学生的ID:')
        if student_id!='':								#if student_id!=''与if not 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:
                with open(filename,'w',encoding='utf-8') as wfile:
                #如果有内容,以只写的方式打开文件,因为要将删除完后的内容,对原有的内容进行覆盖
                    d={}
                    for item in student_old:
                        d=dict(eval(item))				#将字符串转换成字典
                        								#eval()函数用于执行一个字符串表达式,并且返回该表达式的值
                        if d['id']!=student_id:
                            wfile.write(str(d)+'\n')	#删除完的字典写进磁盘文件中.写入文本时要转换成str类型
                        	#删除信息-->用一个新字典(没有要删除学生信息)覆盖原有字典,所以写新字典时,如果遇到要删除的信息就不写入新字典
                        else:
                            flag=True					#如果有相等的,就表示已经删除了,因为没写入到新字典中,设置标记为已删除
                    if flag:
                        print(f'id为{student_id}的学生信息已被删除')
                    else:
                        print(f'没有找到ID为{student_id}的学生信息')
            else:										#磁盘上没有数据(一条数据也没有)
                print('无学生信息')
                break
            show()    									#删除之后要重新显示所有学生信息
            answer=input('是否继续删除?y/b\n')
            if answer=='y':
                continue
            else:
                break

修改U update

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

#修改学生信息
def modify():
    show()
    if os.path.exists(filename):#首先判断文件是否存在
        with open(filename,'r',encoding='utf-8') as rfile:
            student_old=rfile.readlines()
    else:
        return
    student_id=input('请输入要修改的学员的ID:')
    with open(filename,'w',encoding='utf-8') as wfile:
        for item in student_old:#对于文件中的每一个内容
            d=dict(eval((item)))#读取到的是字符串,用eval函数进行转换,转换成字典类型
            if d['id']==student_id:#只有找到信息才可以修改
                print('找到学生信息,可以修改他的相关信息了!')
                while True:
                    try:#修改的过程有可能出错,所以使用try-except
                        d['name']=input('请输入姓名:')
                        d['englist'] = input('请输入英语成绩:')
                        d['python'] = input('请输入Python成绩:')
                        d['java'] = input('请输入Java成绩:')
                    except:#输入有误就会循环while True
                        print('您的输入有误,请重新输入!!!')
                    else:#没有错误就执行else,退出循环
                        break
                wfile.write(str(d)+'\n')#修改完之后再写进文件中(现在是只修改了拿出来的字典的内容)
                print('修改成功!!!')
            else:
                wfile.write(str(d)+'\n')#不需要修改的学生信息继续写入文件
        answer=input('是否继续修改其他学生信息?y/n\n')
        if answer=='y':
            modify()#在函数中写while True,符合条件的一直循环,相当于在条件允许的情况下函数调用自身

查找、读取 R read

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
{0:^30}
0是一个序号,表示格式化输出的第0个字符,依次累加;
30表示输出宽度约束为30个字符;
^表示输出时右对齐,若宽度小于字符串的实际宽度,以实际宽度输出;

#查找学生信息
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 rfile:
                student=rfile.readlines()
                for item in student:
                    d=dict(eval(item))
                    if id!='':#如果ID不为空
                        if d['id']==id:
                            student_query.append(d)
                    elif name!='':#如果姓名不为空
                        if d['name']==name:
                            student_query.append(d)
            #显示查询结果
            show_student(student_query)
            #清空列表
            student_query.clear()#下次执行search()之前清空列表
            anwser=input('是否要继续查询?y/n\n')
            if anwser=='y':
                continue
            else:
                break
        else:#文件不存在
            print('暂未保存学生信息')
            return

#显示指定学生信息
def show_student(lst):
    if len(lst)==0:
        print('没有查询到学生信息,无数据显示!!!')
        return
    #定义标题显示格式
    format_title='{:^6}\t{:^12}\t{:^4}\t{:^9}\t{:^5}\t{:^5}'#{:^4}表示输出宽度约束为4个字符,右对齐;
    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'),#字典可以用get方法,也可以使用方括号
                                 item.get('name'),
                                 item.get('englist'),
                                 item.get('python'),
                                 item.get('java'),
                                 int(item.get('englist'))+int(item.get('python'))+int(item.get('java'))
                                 ))

统计学生总人数

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

#统计学生总人数(判断列表长度)
def total():
    if os.path.exists(filename):
        with open(filename,'r',encoding='utf-8') as rfile:
            students=rfile.readlines()
            if students:#如果不为空
                print(f'一共有{len(students)}名学生')
            else:
                print('还没有录入学生信息')
    else:
        print('暂未保存数据信息....')

显示所有学生信息

在这里插入图片描述
在这里插入图片描述

#显示所有学生信息
def show():
    student_lst=[]
    if os.path.exists(filename):
        with open(filename,'r',encoding='utf-8') as rfile:
            students=rfile.readlines()
            for item in students:
                student_lst.append(eval(item))
            if student_lst:
                show_student(student_lst)
    else:
        print('暂未保存过数据!!!')

排序模块

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

lamada表达式:

add = lambda x, y: x + y

print(add(3, 5))
# Output: 8

排序

def sort():
    show()#先显示所有学生信息
    if os.path.exists(filename):#判断文件是否存在
        with open(filename,'r',encoding='utf-8') as rfile:
            student_list=rfile.readlines()#读出所有数据
        student_new=[]
        for item in student_list:
            d=dict(eval(item))
            student_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':
        student_new.sort(key=lambda x:int(x['englist']),reverse=asc_or_desc_bool)
        #x这个参数是一个字典,根据参数求值,做类型转换后排序
    elif mode=='2':
        student_new.sort(key=lambda x: int(x['python']), reverse=asc_or_desc_bool)
    elif mode=='3':
        student_new.sort(key=lambda x: int(x['java']), reverse=asc_or_desc_bool)
    elif mode=='4':
        student_new.sort(key=lambda x: int(x['englist'])+int(x['python'])+int(x['java']), reverse=asc_or_desc_bool)
    else:
        print('您的输入有误,请重新输入!!!')
        sort()
    show_student(student_new)#排序结束之后再显示一遍

项目打包

在这里插入图片描述
(-cmd中) 输入 pyinstaller -F 内存地址+文件名

Appending:打包文件的新内存地址(记得把原来的文本文件复制过来)
-F的意思是只剩成一个扩展名为.exe的可执行文件
在这里插入图片描述
结果可以得到exe文件的位置

找到文件位置在这里插入图片描述
在这里插入图片描述
把txt文件复制到此目录下
在这里插入图片描述
双击可以打开
在这里插入图片描述
注意事项
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

项目代码

见资源绑定。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1361090.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

1.5 Unity中的数据存储 PlayerPrefs、XML、JSON

Unity中的三种数据存储:数据存储也称为数据持久化 一、PlayerPrefs PlayerPrefs是Unity引擎自身提供的一个用于本地持久化保存与读取的类,以键值对的形式将数据保存在文件中,然后程序可以根据关键字提取数值。 PlayerPrefs类支持3种数据类…

CTFhub-Web-Web前置技能-“302跳转“

题目信息 HTTP临时重定向,题目截图如下所示: 分析过程 看到跳转路径为:http://challenge-d1a96d97eaecf029.sandbox.ctfhub.com:10800/index.html 分析可能存在重定向问题,如果要想获得flag,则可能存在http://chal…

秋招复习之树

目录 前言 1 二叉树 二叉树常见术语 二叉树基本操作 初始化二叉树 插入与删除节点 常见二叉树类型 1. 完美二叉树 2. 完全二叉树 3. 完满二叉树 4. 平衡二叉树 二叉树的退化 2 二叉树遍历 层序遍历 代码实现 复杂度分析 前序、中序、后序遍历 复杂度分析 3 二叉树数组表示 表…

大一,如何成为一名fpga工程师?

​ 1、数电(必须掌握的基础),然后进阶学模电(选学), 2、掌握HDL(HDLverilogVHDL)可以选择verilog或者VHDL,建议verilog就行。 3、掌握FPGA设计流程/原理(推…

YOLOv5源码中的参数超详细解析(6)— common.py

前言:Hello大家好,我是小哥谈。YOLOv5是一种先进的目标检测算法,它可以实现快速和准确的目标检测。common.py文件是YOLOv5中的一个模块,它包含了一些常用的函数和类,用于定义网络结构中的各个模块。该文件中的函数和类被其他文件引用,用于构建整个YOLOv5模型。本节课就结…

「Verilog学习笔记」任意奇数倍时钟分频

专栏前言 本专栏的内容主要是记录本人学习Verilog过程中的一些知识点,刷题网站用的是牛客网 timescale 1ns/1nsmodule clk_divider#(parameter dividor 5) ( input clk_in,input rst_n,output clk_out );parameter CNT_WIDTH $clog2(dividor - 1) ; reg flag1, f…

开发个小破软件——网址导航,解压就能用

网址导航 网站导航也称链接目录,将网站地址或系统地址分类,以列表、图文等形式呈现,帮助快速找到需要的地址。 应用场景 高效查找:网址导航是很好的入口,通过分类清晰的网站推荐,可以迅速访问网站资源。…

【网络层】网际控制报文协议ICMP(湖科大慕课自学笔记)

网际控制报文协议ICMP 1:网际控制报文协议ICMP基本概述 ICMP报文被封装在IP数据报中发送 1:ICMP报文格式 ICMP报文作为IP数据报的数据载荷,IP协议为其添加一个首部使之成为IP数据报 2:ICMP报文类型 ICMP报文分为两大类&#x…

C++string类的介绍及常用函数用法总结

🎉个人名片: 🐼作者简介:一名乐于分享在学习道路上收获的大二在校生🐻‍❄个人主页🎉:GOTXX 🐼个人WeChat:ILXOXVJE🐼本文由GOTXX原创,首发CSDN&a…

java 打印日志的几种方式

java 打印日志的几种方式 Java 日志框架进化史日志门面与日志系统 Log4jslf4jLog4j2slf4jLogbackslf4j 一、先简单介绍五种 (1)最简单的方式,就是system.println.out(error) ,这样直接在控制台打印消息了; (2&#xff…

web前端——clear可以清除浮动产生的影响

clear可以解决高度塌陷的问题&#xff0c;产生的副作用要小 未使用clear之前 <!DOCTYPE html> <head><meta charset"UTF-8"><title>高度塌陷相关学习</title><style>div{font-size:50px;}.box1{width:200px;height:200px;backg…

晶圆代工降价竞争进入白热化,降幅最高15% | 百能云芯

随着半导体产业的不确定性和市况回落&#xff0c;晶圆代工市场再次掀起波澜&#xff0c;“降价大军”再添猛将。 据综合媒体报道&#xff0c;传三星计划在2024年第一季度调降晶圆代工报价&#xff0c;提供5%至15%的折扣&#xff0c;并表示愿意进一步协商。 台积电根据客户的投产…

【Pytorch】学习记录分享10——TextCNN用于文本分类处理

【Pytorch】学习记录分享10——PyTorchTextCNN用于文本分类处理 1. TextCNN用于文本分类2. 代码实现 1. TextCNN用于文本分类 具体流程&#xff1a; 2. 代码实现 # coding: UTF-8 import torch import torch.nn as nn import torch.nn.functional as F import numpy as np…

79 Python开发-sqlmapapiTamperPocsuite

目录 本课知识点本课目的:演示案例:Sqlmap_Tamper模块脚本编写绕过滤SqlmapAPI调用实现自动化SQL注入安全检测Pocsuite3漏扫框架二次开发POC/EXP引入使用 涉及资源: 本课知识点 Request爬虫技术&#xff0c;Sqlmap深入分析&#xff0c;Pocsuite分析&#xff0c;框架代码二次修…

玩转Mysql 二(MySQL的目录结构与表结构)

一路走来,所有遇到的人,帮助过我的、伤害过我的都是朋友,没有一个是敌人。 一、MYSQL目录结构及命令存放路径 1、查看MYSQL数据文件存放路径 mysql> show variables like datadir; 注意:生成环境要提前规划好数据存放目录,存储一般以T为单位闪盘。 2、MYSQL命令存放…

RKE安装k8s及部署高可用rancher之证书私有证书但是内置的ssl不放到外置的LB中 4层负载均衡

先决条件# Kubernetes 集群 参考RKE安装k8s及部署高可用rancher之证书在外面的LB&#xff08;nginx中&#xff09;-CSDN博客CLI 工具Ingress Controller&#xff08;仅适用于托管 Kubernetes&#xff09; 创建集群k8s [rootnginx locale]# cat rancher-cluster.yml nodes:- …

【开源】基于JAVA语言的智能教学资源库系统

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 数据中心模块2.2 课程档案模块2.3 课程资源模块2.4 课程作业模块2.5 课程评价模块 三、系统设计3.1 用例设计3.2 数据库设计3.2.1 课程档案表3.2.2 课程资源表3.2.3 课程作业表3.2.4 课程评价表 四、系统展示五、核心代…

vue2 element 弹出框拖拽会出现一层阴影问题

问题如图所示&#xff1a; 因增加 draggable 属性导致我弹窗表单清空文本框时&#xff0c;从右向左选中字体会出现拖拽阴影效果 去掉 draggable 即可 <template><div class"sys-jobTrigger-container"><el-dialog:visible.sync"state.isShowD…

抖店不好做?类目赛道没选对、选品能力跟不上,做不起来很正常!

我是王路飞。 抖店一直做不起来&#xff1f; 新手吐槽抖店不好做&#xff0c;绝大多数都有以下两个问题存在&#xff1a;类目赛道没选对、选品能力跟不上。 那你们做不起来也是很正常的一件事了。 今天围绕抖店的核心&#xff0c;给你们聊下&#xff0c;正确的运营抖店思路…

IP2312U_VSET 5V 2A 单节锂电池同步开关降压充电IC

IP2312U是一款5V输入&#xff0c;支持单节锂电池同步开关降压充电管理的IC。 IP2312U集成功率MOS&#xff0c;采用同步开关架构&#xff0c; 使其在应用时仅需极少的外围器件&#xff0c;并有效减小整体方案的尺寸&#xff0c;降低BOM 成本。 IP2312U的升压开关充电转换器工作频…