You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
StudentSystem/README.md

495 lines
15 KiB

2 years ago
# 学生成绩管理系统
2023年5月21日
2 years ago
2 years ago
组长:张桐桐
组员:孟婷玉 李玉璇 周羽凡
下载地址https://bdgit.educoder.net/pn8rjlxip/StudentSystem.git
## 项目简介
本学生成绩管理系统是为教师提供管理班级成绩的工具,该系统可以实现的对学生的成绩进行增、删、改、查、信息保存和信息导入等基本功能,以及对学生成绩排序和分段的扩展功能,有利于对学生成绩管理。
项目开发过程中采用 Kanban看板进行任务管理和分工协作并使用 Git 对程序代码和文档进行版本管理。任务分工情况如下:
| 任务 | 设计 | 开发 | 测试 | 文档 |
| ---- | ---- | ---- | ---- | ---- |
| C1-C3 菜单驱动的用户界面 |张桐桐| 张桐桐 | 李玉璇 | 张桐桐 |
| C4 添加学生信息 | 李玉璇| 李玉璇 | 周羽凡 | 李玉璇|
|C5-C6 求和求平均 | 周羽凡 | 周羽凡 | 孟婷玉 | 周羽凡|
|C7-C9 排序 | 孟婷玉 | 孟婷玉 | 张桐桐 | 孟婷玉 |
| C10 学生信息查询 | 张桐桐 | 张桐桐 | 李玉璇 | 张桐桐 |
|C11 统计学生信息| 李玉璇 | 李玉璇 | 周羽凡 | 李玉璇 |
|C12 打印学生信息 | 周羽凡 | 周羽凡 | 孟婷玉 | 周羽凡 |
| C13 将学生信息读入文件| 孟婷玉 | 孟婷玉 | 张桐桐 | 孟婷玉 |
| C14 从文件中读取学生信息 | 张桐桐 李玉璇| 孟婷玉 | 周羽凡 |张桐桐|
每个成员的工作量(百分比):
| 张桐桐 | 李玉璇 | 周羽凡 |孟婷玉|
| ---- | ---- | ---- |----|
| 30 | 30 | 20 | 20 |
关于学生成绩管理系统
设计一个学生成绩管理系统要求采用行菜单界面进行交互具备读取、保存、打印、查询、插入和排序等基本功能能够以表格和图表形式展示数据采用CSV格式保存数据。
# 系统的功能性需求:
数据的读取、保存、打印、查询、插入、排序和图表展示。
系统的非功能性需求:
菜单驱动的命令行交互界面
需求分析
分析系统的功能需求和界面需求,编制用户手册如下。
2 years ago
2 years ago
C1: 启动程序
命令行中执行命令./app,系统启动,显示提示信息,然后显示功能菜单,等待用户输入命令。
````
学生成绩管理
1 输入分数
2 计算每个学生各门成绩的总分和平均分
3 计算每个课程的总分和平均分
4 按分数降序排序
5 按分数升序排序
6 按数据升序排序
7 按姓名的字典顺序排序
8 查找数据
9 查找姓名
10 统计分析
11 列表记录
12 写入文件
13 读取文件
0 退出
请输入你的选择:
````
C2: 显示命令菜单
调用 Menu() 函数显示命令菜单,用户输入选项后,将结果返回主函数
````
学生成绩管理
1 输入分数
2 计算每个学生各门成绩的总分和平均分
3 计算每个课程的总分和平均分
4 按分数降序排序
5 按分数升序排序
6 按数据升序排序
7 按姓名的字典顺序排序
8 查找数据
9 查找姓名
10 统计分析
11 列表记录
12 写入文件
13 读取文件
0 退出
请输入你的选择:
````
C3: 退出程序
选择菜单命令 0 ,再输入 y 确认,则退出程序。
````
请输入你的选择: 0
你确定你想进入吗?(确定/不确定): 确定
结束程序!
````
2 years ago
2 years ago
C4: 添加学生信息
选择菜单命令 1 假设n=4,m=3,提示输入学生的学号,姓名和成绩,然后利用循环逐个输入学生的学号和姓名以及各科成绩。
````
请输入你的选择1
输入学生的学号,名字和成绩:
2214111018 李玉璇 100 95 86
2214111038 张桐桐 77 89 99
2214111026 孟婷玉 85 91 98
2214111022 周羽凡 75 89 100
````
2 years ago
C5: 计算学生各门课程总分和平均分
选择菜单命令 2 ,计算学生各门课程总分和平均分,然后利用循环逐个输出学生的顺序,总成绩和平均分,结果都取整数。
````
请输入你的选择2
学生 李玉璇: 总分 = 281 平均分 = 93
学生 张桐桐: 总分 = 265 平均分 = 88
学生 孟婷玉: 总分 = 274 平均分 = 91
学生 周羽凡: 总分 = 264 平均分 = 88
````
c6:计算每门课程的总分和平均分
选择菜单命令 3计算每门课程的总分和平均分然后利用循环逐个输出每门课程的总分和平均分结果都取整数。
````
请输入你的选择: 3
课程 1 总分 = 337 平均分 = 84
课程 2 总分 = 364 平均分 = 91
课程 3 总分 = 383 平均分 = 95
````
c7学生总分排序
如果a < b, 4sum
如果a > b则按降序排序。选择菜单命令 5按选择法将数组sum的元素值按降序进行排序显示提示信息最后打印出学生成绩。
````
请输入你的选择: 4
按分数降序排序:
2214111038 ZhangTongtong 100 95 86 281 93
2214111018 LiYuxuan 85 91 98 274 91
2214111026 MengTingyu 77 89 99 265 88
2214111022 ZhouYufan 75 89 100 264 88
请输入你的选择: 5
按分数升序排列:
2214111022 ZhouYufan 75 89 100 264 88
2214111026 MengTingyu 77 89 99 265 88
2214111018 LiYuxuan 85 91 98 274 91
2214111038 ZhangTongtong 100 95 86 281 93
````
c8学号顺序排序
选择菜单命令 6按学号从小到大进行排序显示提示信息最后打印学生信息。
````
请输入你的选择: 6
按学号降序排列:
2214111018 LiYuxuan 85 91 98 274 91
2214111022 ZhouYufan 75 89 100 264 88
2214111026 MengTingyu 77 89 99 265 88
2214111038 ZhangTongtong 100 95 86 281 93
````
C9: 姓名顺序排序
选择菜单命令 7 ,按姓名的字典顺序进行排序,显示提示信息,最后打印学生信息。
````
请输入你的选择: 7
按名称按字典顺序排序:
2214111018 LiYuxuan 75 89 100 264 88
2214111022 ZhouYufan 77 89 99 265 88
2214111026 MengTingyu 100 95 86 281 93
2214111038 ZhangTongtong 85 91 98 274 91
2 years ago
````
C10: 学生信息查询
选择菜单命令 8 ,提示输入学生学号,若该学号存在,则输出学生信息;否则提示没有找到并结束。
````
请输入你的选择: 8
输入你想搜寻的学号:2214111018
2214111018 LiYuxuan 75 89 100 264 88
1 输入成绩
2 计算每门课程的总分和平均分
3 计算每名学生的总分和平均分
4 按分数降序排序
5 按分数升序排序
6 按学号升序排序
7 按名称按字典顺序排序
8 按数字搜索
9 按名字搜索
10 统计分析
11 列表记录
12 写一个文件
13 从文件中读取
0 退出
请输入你的选择: 8
输入你想搜寻的学号:2214111001
没有找到!
选择菜单命令 9 ,提示输入学生姓名,若该姓名存在,则输出学生信息;否则提示没有找到并结束。
请输入你的选择: 9
输入你想搜寻的名字:ZhangTongtong
2214111038 ZhangTongtong 85 91 98 274 91
1 输入分数
2 计算每门课程的总分和平均分
3 计算每名学生的总分和平均分
4 按分数降序排序
5 按分数升序排序
6 按学号升序排序
7 按名称按字典顺序排序
8 通过学号搜索
9 通过姓名搜素
10 统计分析
11 列表记录
12 写一个文件
13 从文件中读取
0 退出
请输入你的选择: 9
请输入你想搜索的名字:GuoJiahui
Not found!
````
C11: 统计各分数段学生人数及所占百分比
选择菜单命令 10提示输入学生成绩通过循环得出各分数段学生人数及所占百分比
````
请输入你的选择: 10
关于课程1:
<60 0 0.00%
60-70 0 0.00%
70-80 2 50.00%
80-90 1 25.00%
90-100 0 0.00%
100 1 25.00%
For course 2:
<60 0 0.00%
60-70 0 0.00%
70-80 0 00.00%
80-90 2 50.00%
90-100 2 50.00%
100 0 0.00%
For course 3:
<60 0 0.00%
60-70 0 0.00%
70-80 0 0.00%
80-90 1 25.00%
90-100 2 50.00%
100 1 25.00%
````
C12: 打印学生信息
选择菜单命令11打印
````
请输入你的选择11
2214111018 李玉璇 100 95 86 281 93
2214111038 张桐桐 77 89 99 265 88
2214111026 孟婷玉 85 91 98 274 91
2214111022 周羽凡 75 89 100 264 88
````
C13: 将学生信息保存在文件中
选择菜单命令 12 ,将学生信息保存在文件 student.txt 中。如果文件不存在,则给出错误信息并退出程序,否则逐个读入
````
请输入你的选择12
未能打开你的成绩!
1 输入成绩
2 计算所有课程的总分和平均值
3 计算所有学生的总分和平均值
4 按分数降序排列
5 按分数升序排列
6 按数字升序排列
7 按名字字母排列
8 按数字搜索
9 按名字搜索
10 统计分析
11 列表记录
12 写入文件
13 从文件中读取
0 退出
请输入你的选择12
2214111018 李玉璇 100 95 86 281 93
2214111038 张桐桐 77 89 99 265 88
2214111026 孟婷玉 85 91 98 274 91
2214111022 周羽凡 75 89 100 264 88
````
C14从文件中读取学生信息
选择菜单命令 13 ,从文件中读取学生的学号、姓名及成绩等信息写入到结构体数组 stu 中。如果文件为空,则给出错误信息并退出程序,反之,逐个读入
````
请输入你的选择13
未能打开你的成绩!
1 输入成绩
2 计算所有课程的总分和平均值
3 计算所有学生的总分和平均值
4 按分数降序排列
5 按分数升序排列
6 按数字升序排列
7 按名字字母排列
8 按数字搜索
9 按名字搜索
10 统计分析
11 列表记录
12 写入文件
13 从文件中读取
0 退出
请输入你的选择12
2214111018 李玉璇 100 95 86 281 93
2214111038 张桐桐 77 89 99 265 88
2214111026 孟婷玉 85 91 98 274 91
2214111022 周羽凡 75 89 100 264 88
2 years ago
````
2 years ago
2 years ago
# 概要设计
2 years ago
系统主要分为用户界面和数据处理两大模块。
用户界面模块包括输入学生成绩ReadScore、计算学生总分和平均分AverSumofEveryStudent、计算总分和平均分AverSumofEveryCourse、按选择发将数组元素排序Sortbyscore、使数据按升序排序Ascending、使数据按降序排序Descending、交换单精度浮点数据SwapFloat、交换长整型数据SwapLong、交字符串SwapChar、按选择法将数组元素按从低到高排序、交换实现字符串按字典顺序排序SortbyName、按学号查找学生成绩并显示查找结果SearchbyNum、按姓名的字典顺序排出成绩表 、统计各分数段的学生人数及所占的百分比 、打印学生成绩 、输出学生的学号、姓名及课程的成绩到文件student.txt中 、从文件中读取学生的学号、姓名及成绩等信息写入到结构体数组stu中
上述各模块通过主程序main进行调用系统模块图如下。
2 years ago
![添加库存记录流程图](0.drawio.svg)
2 years ago
各模块的主要功能如下:
main
系统主函数模块,显示菜单,根据用户选择的菜单命令,执行相关操作。
2 years ago
ReadScore
输入n个学生的m门课成绩
2 years ago
2 years ago
AverSumofEveryStudent
计算每个学生各门课程的总分和平均分
AverSumofEveryCourse
计算每门课程的总分和平均分
SortbyScore
按选择法将数组sum的元素值排序
Ascending
使数据按升序排序
Descending
使数据按降序排序
SwapFloat
交换两个单精度浮点型数据
SwapLong
交换两个长整型数据
SwapChar
交换两个字符串
AsSortbyNum
按选择法将数组num的元素值按从低到高排序
AsSortbyNum
交换法实现字符串按字典顺序排序
SearchbyNum
按学号查找学生成绩并显示查找结果
SearchbyName
按姓名的字典顺序排出成绩表
StatisticAnalysis
统计各分数段的学生人数及所占的百分比
PrintScore
打印学生成绩
WritetoFile
输出n个学生的学号、姓名及m门课程的成绩到文件student.txt中
2 years ago
2 years ago
ReadfromFile
从文件中读取学生的学号、姓名及成绩等信息写入到结构体数组stu中
2 years ago
详细设计
针对概要设计
2 years ago
## main
2 years ago
Step 1:初始化,
Step 2:根据用户选择的命令执行相应的操作,
Step 2.1:显示菜单,
Step 2.2:选择菜单命令 c,
Step 2.3:if c == 1 then ReadScore,
Step 2.4:if c == 2 then AverSumofEveryStudent,
Step 2.5:if c == 3 then AverSumofEveryCourse,
Step 2.6:if c == 4 then SortbyScore(Descending),
Step 2.7:if c == 5 then SortbyScore(Ascending),
Step 2.8:if c == 6 then AsSortbyNum,
Step 2.9:if c == 7 then SortbyName,
Step 2.10:if c == 8 then SearchbyNum,
Step 2.11:if c == 9 then SearchbyName,
Step 2.12:if c == 10 then StatisticAnalysis,
Step 2.13:if c == 11 then PrintScore,
Step 2.14:if c == 12 then WritetoFile,
Step 2.15:if c == 13 then ReadfromFile,
Step 2.16:if c == 0 then exit,
2 years ago
## 详细设计
2 years ago
![系统模块图](xitong.drawio.svg)
2 years ago
2 years ago
````
2 years ago
1·输入n个学生的m门课成绩
ReadScore
Step 1:显示提示信息,要求输入学生的学号,姓名和成绩
Step 2利用循环输入学生的学号成绩和各科成绩
2 years ago
````
2 years ago
![n个学生的m门课成绩](1.drawio.svg)
2 years ago
````
2 years ago
2·计算每个学生各门课程的总分和平均分
AverSumofEveryStudent
step1输入一门学生的成绩
step2将学生成绩相加输出总分
step3输出课程平均值
step4输入下一门课程
2 years ago
````
2 years ago
![总分平均值](2.drawio.svg)
2 years ago
````
2 years ago
3·计算每门课程的总分和平均分
AverSumofEveryCourse
step1输入第一门课程的所有学生的成绩
step2将成绩相加输出科目总分
step3总分/人数,输出课程平均分
step4输入下一个科目
2 years ago
````
2 years ago
![课程总分平均分](3.drawio.svg)
2 years ago
````
4·按选择法将数组sum的元素值排序
SortbyScore
Step 1:利用循环将i赋值给k
Step 2:用循环从i+1到n-1比较,将较小的赋给k
Step 3:如果k与i不相等每一课的成绩交换总分平均分学号姓名依次交换
````
![lyx4](c4.drawio.svg)
2 years ago
5.按选择法将数组num的元素值按从低到高排序
2 years ago
````
2 years ago
Step 1:利用 for 循环给 i 赋值为0
Step 2:利用 if 条件判断学号是否致
Step 3:利用二次循环找出所有符合条件件的学
Step 4:利用 i 件语句能否找到该学生
2 years ago
````
2 years ago
![排序1](mty5.drawio.svg)
2 years ago
2 years ago
6.交换法实现字符串按字典顺序排序
2 years ago
````
2 years ago
step 1:利用for循环将相邻的两个姓名作比较
step 2:如果前一个字符串大于后一个利用for循环交换m门课程的成绩
step 3:依次交换
2 years ago
````
2 years ago
![排序2](mty6.drawio.svg)
2 years ago
2 years ago
7.按学号查找学生成绩并显示查找结果
2 years ago
````
2 years ago
Step 1:利用for循环给i赋值为0
Step 2:利用if条件判断学号是否一致
Step 3:利用二次循环找出所有符合条件的学生
Step 4利用if条件语句能否找到该学生
2 years ago
````
2 years ago
![查找](mty7.drawio.svg)
2 years ago
2 years ago
8.按姓名的字典顺序排出成绩表
````
Step 1:利用for循环给i赋值为0
Step 2:利用of条件语句和循环判断是否此学生并显示结果
2 years ago
````
2 years ago
![排序3](mty.8.drawio.svg)
2 years ago
9·统计各分数段的学生人数及所占的百分比
````
StatisticAnalysis
step1:输入每个学生的成绩
step2:判断输入成绩所在的分数段
step3:将各个分数段的成绩个数除以学生总人数并乘以百分百
````
2 years ago
![统计](c9.drawio.svg)
2 years ago
10·打印学生成绩
````
PrintScore
step1:输入学生的学号,姓名.
step2:查找该学生的成绩
step3:输出该学生的成绩
````
2 years ago
![打印](c10.drawio.svg)
2 years ago
11·输出n个学生的学号、姓名及m门课程的成绩到文件student.txt中
````
WritetoFile
step1:输入学生的学号和姓名
step2:查找该学生的所有课程成绩
step3:将成绩保存到文件student.txt中
````
2 years ago
![文件](c11.drawio.svg)
2 years ago
12·从文件中读取学生的学号、姓名及成绩等信息写入到结构体数组stu中
````
ReadfromFile
step1:查找文件
step2:从文件中读取学生的学号姓名成绩
step3:将信息写入到数组stu中
````
2 years ago
![stu](c12.drawio.svg)
2 years ago