一、程序功能(Function)
1、功能概述
利用Python完成一个学生信息的增删改查程序,主要涉及知识点:程序控制结构(做多级菜单)、文件读写操作(学生信息要保存到磁盘上的文件里)、利用函数实现功能模块化。
2、思维导图
二、学生实体(Entity)
1、思维导图
2、关系模式
学生(学号, 姓名, 性别, 年龄, 班级, 专业, 系部, 电话)
3、学生表
学号 | 姓名 | 性别 | 年龄 | 班级 | 专业 | 系部 | 电话 |
---|---|---|---|---|---|---|---|
2020001 | 陈岚 | 女 | 19 | 2017级6班 | 语文 | 人文学院 | 18228255321 |
2020002 | 陈冉 | 男 | 20 | 2017级1班 | 工程造价 | 建筑学院 | 15892339015 |
2020003 | 汪华龙 | 男 | 19 | 2017级1班 | 环境 | 园林学院 | 115648561332 |
2020003 | 赖跃成 | 男 | 19 | 2017级1班 | 铁道维修 | 铁道学院 | 1549865166 |
这学期,我们还没有学习MySQL,所以我们将学生信息保存到文本文件里,用空格来隔开每个字段。
三、读取学生文件
文件结构是由若干行若干列构成,一行一行地读取,每一行读取出来的字符串,通过空格拆分成一个列表,所有行读取出来之后就自然构成列表的列表,即二维列表。
1、演示用二维列表保存多个学生信息
创建六个列表:student1、student2、student3、student4、student5和student6,然后添加到student是列表里
并直接输出student列表
格式输入students
2、读取学生文件数据,保存到二维列表里
查看学生文件位置
切换工作目录
读取学生文件,保存到二维列表并输出
四、对学生二维列表进行增删改查操作
1、增加学生记录
目前students里有四个元素(学生)
添加一个新元素(学生)
输出更新之后的students二维列表
2、查询学生记录
(1)按学号查询学生记录
这个程序有个缺陷,如果没有查询到,就没有任何输出信息,按理应该给用户一个提示:“查无此人!”
(2)按姓名查询
3、修改学生记录
修改学号为"2020003"的学生记录,将年龄改为“18”,电话改为“15834345670”
修改学号为“2020007”的学生记录,将年龄改为“20”,电话改为“13967678900”
4.删除学生记录
六、构建学生信息管理多级菜单系统
(一)构建多级菜单系统
编写程序 - 学生信息管理.py
运行程序,查看效果
二)实现学生信息管理功能模块
1、编写查询全部学生记录功能
编写get_all_students()、display_all_students()函数
2、编写增加学生记录功能
编写add_student()函数代码
查看添加了新记录的学生.txt文件
3.编写删除学生记录功能
编写delete_student()函数代码
运行程序,查看效果
5.改善查询学生记录功能
以姓名以及学号 查找
结果为
4.编写修改学生记录功能
编写modify_student()函数
结果