精华内容
下载资源
问答
  • 数据库原理课程设计报告学生成绩管理系统设计.doc
  • 学生成绩管理系统,功能分为: (1)添加功能:程序能够添加不同学生的记录,提供选择界面供用户选择所要添加的类别,要求学号要唯一,如果添加了重复学号的记录时,则提示数据添加重复并取消添加。 (2)查询功能:...
  • 数据库原理课程设计报告(学生成绩管理系统)
  • 学生成绩管理系统E-R图及关系模型设计 创建一个学生成绩数据库涉及的信息包括校内所有的系班级学生课程和学生成绩 本章首先完成学生成绩数据库的设计具体数据库的建立在后面章节中完成 学生成绩数据库的信息内容为每...
  • 数据库原理与应用学生成绩管理系统设计实训报告
  • 《oracle学生成绩管理系统设计》由会员分享,可在线阅读,更多相关《oracle学生成绩管理系统设计(11页珍藏版)》请在人人文库网上搜索。1、阶段1.1成绩管理系统实体关系设计一、实验目的和要求(1)熟练掌握实体关系...

    《oracle学生成绩管理系统设计》由会员分享,可在线阅读,更多相关《oracle学生成绩管理系统设计(11页珍藏版)》请在人人文库网上搜索。

    1、阶段1.1成绩管理系统实体关系设计一、实验目的和要求(1)熟练掌握实体关系设计的方法。(2)通过需求分析结果,掌握E-R图。二、实验内容和原理实体关系设计是在需求分析的一个环节过程,在这一过程中产生E-R图,该图由实体、属性和联系三个要素构成。逻辑结构设计的任务就是把概念设计阶段建立的基本E-R图按照选定的系统软件支持的数据模型,转换成相应的逻辑模型。这种转换要符合关系数据模型的原则。E-R图向关系模型转换时要解决如何将实体和实体间的联系转换为关系,并确定这些关系的属性和码,这种转换一般按下面的原则进行。(1)一个实体转换为一个关系,实体的属性就是关系的属性,实体的码就是关系的码。(2)一个联。

    2、系也转换为一个关系,联系的属性及联系所连接的实体的码都转换为关系的属性,但关系的码会根据联系的类型变化。三、主要仪器设备计算机一台、Powerdesinger运行环境四、操作方法与实验步骤在成绩管理系统中,需要管理学生、课程和成绩,以及它们之间的联系。因此在该系统的E-R图中,实体分别为学生、老师、课程。为了便于掌握,学生实体的属性分别有学号、姓名、性别;课程实体的属性有课程编号、课程名称、学期、课程学分;教师实体的属性有教师编号、姓名、性别。学生实体与课程实体有选课关系,而且一个学生可以选择多门课程,一门课程也可以被多个学生选择,因此学生和课程之间的联系是m:n联系。教师实体与课程实体有教授。

    3、关系,一名教师可以教多门课程,一门课程也可以被多个教师教授,因此教师和课程之间的联系是m:n联系。学生在选课后会产生成绩,教师授课后会产生授课地点及授课学期。根据上述分析,绘出的E-R图如下图所示。阶段1.2 成绩管理系统结构设计一、实验目的和要求1.了解数据库中列的属性以及各个属性的含义。2.掌握为不同的列选择不同的属性及范围。二、实验内容和原理在管理信息系统中,物理结构设计主要是指如何将通过逻辑结构设计所得的系统逻辑结构型转换为物理模型,并明确地指出系统的物理存储结构。本实验主要是利用CASE工具集PowerDesigner对成绩管理系统进行物理结构的设计。三、主要仪器设备计算机一台、Po。

    4、werdesinger 运行环境、Oracle运行环境四、操作方法与实验步骤在物理结构设计中需要考虑为每列设计合适的数据类型。成绩管理系统中,学生(学号、姓名、性别)关系里,学号采用int来表示就可以了,而姓名设置成varchar2(20),性别只需要设置为char(2)。因为性别不是男就是女,因此只会占用两个字节。所以最终我们可以将其物理表结构设置为:t_student(stuid int,stuname varchar2(20),sex char(2)。依照上述,课程的物理表结构为:t_course(couid int,couname varchar2(20),term char(2),c。

    5、redit number(3,1))。教师的物理存储表结构为:t_teacher(teaid int,teaname varchar2(20),sex char(2)。选课的物理表结构为:t_selcour(sid int,cid int,score number .(4,2))。教课的物理表结构为:t_teacour(tid int,cid int,teaaddr varchar2(30),term char(2))。(1) 通过手动编写SQL语句方式建立数据库后台上述创建了代表学生实体的表t_student,其中stuid设置为主键,唯一标识一个学生。表t_course用来代表课程实体,其。

    6、中采用couid来标识一门课程。当课程名称的长度大于20个字符时,varchar2可以自动扩展。物理实体在物理结构中用t_teacher表来表示,teaid用来唯一标识一位教师,因此其不能空选课表t_selcour中学生编号参考t_student表中的stuid,此时sid为外键,课程编号cid也作为外键参考t_course中的couid(2)通过PowerDesigner建立数据库后台。第四步:到此,系统的概念模型就全部设计好了。接下来单击菜单“工具”“生成物理属性模型”选项,就会弹出“物理数据模型生成选项”对话框,如下图:在“常规”选项卡中选择“生成新的物理模型”单选钮,并选择DBMS为“。

    7、OPACLE Version 10g”,“名称”文本“MyPhysicalDataModel”,并单击“确认”按钮,在弹出得到路径选择对话框中输入你想要放置生成的物理数据模型文件的位置,系统就会自动在指定的路径下生成一个名为“MyPhysicalDataModal.pdm”的文件,并生成系统的物理模型,如下图CONGC从菜单中选择 Database -Generate Database选项。PowerDesigner将会在指定的路径下生成一个名字为*.sql 的文本文件。里面存放可供Oracle 执行的用来建立数据库实体的SQL语句。阶段1.3 成绩管路系统存储过程设计一、实验目的和要求(1)。

    8、了解存储过程的设计目的以及方法。(2)掌握存储过程的创建。二、实验内容和原理存储过程是在数据中定义的程序块,它存放在数据库服务端数据字典里。采用存储过程可以提高过程代码程序的执行速度和代码共享度。具体有以下几个特点。(1)过程存放在服务器端,减少了网络传输的延时,提高了速度。(2)过程在执行一次之后,会驻留内存,后续的执行无需再经编译过程,提高了执行效率。三、主要仪器设备计算机一台,Oracle运行环境四、操作方法与实验步骤1、创建存储过程先向表t_student中插入数据,具体如下所示2、每次向表t_student中插入数据时,只需要运行该过程就可以了。具体如下所示。表t_student中的。

    9、列stuid被设置为主键,因此不可以存在重复值。在第二次运行时,因为输入的第一个参数id与表中已存在的数据相同,所以插入时出现错误。3、继续向表中插入两条记录,其中当参数id不重复时,过程成功完成。4、不仅可以通过存储过程向表中插入数据,也可以通过一般的SQL语句向表中插入数据,如下所示。5、向表中插入数据时,需要注意数据类型以及长度都需要与表中定义的相符,否则会出现错误,具体如下所示。6、t_course表中列term被定义为char且长度为2,因此在插入数据时该列最大长度为2,超过该值会出现错误。课程表中只有已经存在的课程编号才能被插入到选课表中,否则会出错,这样就保证了数据的一致性。7、。

    10、t_selcour表的另外一个外键为第一列sid,在插入时只有当该值存在于学生表中的学生编号时,才能被成功插入,否则也会出现错误,具体如下所示。8、对于向表t_teacour中插入数据时,同样需要满足外键参考主键的约束条件,具体如下所示。9、向表t_teacour中插入一行记录,其中tid存在于表t_teacher的列teaid中,cid存在于表t_course列couid中。如果插入的值不符合外键约束条件,会出现错误,具体如下所示。10、在完成对表插入值后,可以关联表查询记录。比如:查询教师编号为1的教师所带的课程编号、教师姓名、课程名称、课程学分信息,具体如下所示。实现了查询编号为1的老师。

    11、所带的课程编号、课程名称等信息。在查询时,为表命名别名时为了方便,各个表的连接通过主键外键约束来实现。查看t_course及t_selcourse中的值五、实验结果与分析实验结果如上截图所示。六、讨论、心得grant select不支持对表中选定的几列授权,只能将整个表的select权限授权出去。所以实验中先建立了基于选课信息表的视图SelectiveInfo1,视图中包含成绩列,学号列以及班级列(不包含其他的列)再将对视图SelectiveInfo1的select权限授予角色teacher。不同的用户可以创建相同的表格,teacher用户创建了table1,student用户也创建了table1,且这两个表格式完全相同的,那么其他用户需要用这两个表格时,可以用teacher. table1和student. table1加以区分。实验中遇到的问题可以上网百度,网上资源很丰富。

    展开全文
  • 课程设计:c++实现学生成绩管理系统

    万次阅读 多人点赞 2020-11-28 10:59:08
    学生成绩管理系统课程设计,作为计算机科学专业学生的一门必修课,印象非常深刻,上机,编码,写报告,答辩,最后很多人勉强完成了功课,但是却很少能学到东西,算是一种遗憾吧,即使我们毕业了,仍然会想回去再做一...

        学生成绩管理系统课程设计,作为计算机科学专业学生的一门必修课,印象非常深刻,上机,编码,写报告,答辩,最后很多人勉强完成了功课,但是却很少能学到东西,算是一种遗憾吧,即使我们毕业了,仍然会想回去再做一遍。

        今天就来复习一遍这个课题,也让自己学习学习。

        学生成绩管理系统,对于刚学编程的人来说,是有一些难度的,有循环要考虑,还需要注意界面打印,菜单管理,输入输出控制,文件读写操作,排序算法等等技巧。

        学生成绩管理系统,可以分为如下几个功能:

         

        系统菜单:首先进入系统,我们会看见我们的系统菜单,根据提示,我们可以选择我们需要的操作编号:

        

        输入学生成绩:该功能是每次录入都会将新录入信息替换原来的学生成绩信息,仅限初次使用,后续慎用,类似新增,但是它是每次都会擦除原来学生信息。

        

        统计学生成绩:将学生成绩按照平均分显示,是一个简单的输出。

        

        查找学生成绩:按照学生学号查询。

        

        修改学生成绩:这里只是将对应学号的学生成绩修改,而不是连班级、学号、姓名也改变。

        

        修改之后:

        

        删除学生成绩:按照学号删除对应学生成绩信息记录。

        

        删除之后,学号为3的成绩记录就没有了:

        

        新增学生成绩:在原来学生成绩的基础上,新增学生成绩信息。

        

        按平均分排序:按照平均分降序排序,这里使用了简单的冒泡排序算法。

        

        显示学生成绩:遍历所有学生成绩,然后打印出来。

        

        退出管理系统: 退出菜单。

        学生成绩管理系统,主要是管理学生成绩信息的,这里可以简单的理解有这么一个对象,包含班级、学号、姓名、电子成绩、C++成绩、多媒体成绩、英语成绩、数学成绩、大学物理成绩、体育成绩、政治成绩,平均分这几项属性。这样我们可以定义这样的一个学生Student结构体或者类:

    class Student{
    private:
      char class_0[20]; //班级,因为class是关键字,我们用了class_0来表示班级
      int num;          //学号
      char name[8];     //姓名  姓名定义的长度是8,如果输入拼音或者英文,很有可能超出这个范围,要小心处理。
      float elec;       //电子
      float c_program;  //C++
      float media;      //多媒体
      float english;    //大学英语
      float math;       //高等数学
      float sport;      //体育
      float polity;     //政治
      float average;    //平均分  
    }stu[100];

        课程分数实际上都是整数,很难有小数点,但是平均分大概率是一个浮点数,所以必须用浮点数表示。但是使用浮点数表示分数也没有问题。 

        因为数据来源于文本文件,所以这里对文件读写操作非常频繁,涉及到读写操作的:1:输入,4:删除,5:修改,6:新增,7:排序。这些操作都有一个共同的特点,就是需要写入操作(Write)。这里因为是文件系统,没有办法做到增量修改,每次只能是覆盖式的写入。为了保留原来的纪录,可能还需要读取操作(Read)。

        这个程序,如果第一次运行,没有进行学生信息录入,即菜单项中的[1]输入学生成绩,默认如果执行[8]显示所有学生成绩,会报错,因为没有score.txt文件生成,只有进行了[1]操作之后,才会生成这个文件,所以为了避免程序报错,我们可以在项目路径下创建一个score.txt文件。

        默认,我们手动创建的这个文件中如果有中文,编码默认是UTF-8,保存之后,显示在界面上,会显示乱码,因为cmd终端默认的编码是ANSI格式,所以这个文件我们需要保存为ANSI格式,才能正确显示中文。

        初始文件score.txt格式如下:

    2
    
    10601	2	刘莹	86	84	90	80	88	82	85	85
    10601	1	吴昊	89	90	91	90	89	91	90	90

        该文件第一行,表示学生成绩总数,这个数字需要我们手动写入到文件里面,后面换行才是学生成绩,没有列标题,依次对应:班级、学号、姓名、电子成绩、C++成绩、多媒体成绩、英语成绩、数学成绩、大学物理成绩、体育成绩、政治成绩、平均分。一条记录占一行。

         读的时候,首先读取记录数,然后按行读取学生成绩信息,所以有这样的代码:

        

        同理,写入文件的时候,我们也要先写入记录数,然后依次写入学生成绩信息:

         

        我们没有使用很复杂的数据结构,这里就是利用了数组来操作学生成绩,涉及到修改的操作,基本就是先将文本文件中的数据读入数组,然后操作数组来实现新增,修改,删除,排序操作,最后将新的数组写入文件成为新的文件。 

         下面给出源码:

    #if defined(_MSC_VER) && !defined(_CRT_SECURE_NO_DEPRECATE)
    #define _CRT_SECURE_NO_DEPRECATE
    #endif
    #include <iostream>
    #include <fstream>
    #include <string>
    using namespace std;
    class Student{
    public:
    	friend void Input(Student stu[]);
    	friend void Statistic(Student stu[]);
    	friend void Lookup(Student stu[]);
    	friend void Modify(Student stu[]);
    	friend void Delete(Student stu[]);
    	friend void Output(Student stu[]);
    	friend void Insert(Student stu[]);
    	friend void Sort(Student stu[]);
    	friend void Write(Student stu[],int n);
    	friend int Read(Student stu[]);
    private:
    	int num;
    	char name[8];
    	char class_0[20];
    	float elec;
    	float c_program;
    	float english;
    	float math;
    	float media;
    	float sport;
    	float polity;
    	float average;
    	int order;
    }stu[100];
    
    void Write(Student stu[], int n) {
    	fstream myFile;
    	myFile.open("score.txt", ios::out | ios::binary);
    	if (!myFile) {
    		cout << "score.txt can't open!" << endl;
    		abort();
    	}
    	int count = n;
    	myFile << count << endl<<endl;
    	for (int i = 0; i < count; i++) {
    		myFile << stu[i].class_0  << "\t"
    			   << stu[i].num      << "\t"
    			   << stu[i].name     << "\t"
    			   << stu[i].elec     << "\t"
    			   << stu[i].c_program<< "\t"
    			   << stu[i].media    << "\t"
    			   << stu[i].english  << "\t"
    			   << stu[i].math     << "\t"
    			   << stu[i].sport    << "\t"
    			   << stu[i].polity   << "\t"
    			   << stu[i].average  << endl;
    	}
    	myFile.close();
    }
    
    int Read(Student stu[]) {
    	fstream myFile;
    	myFile.open("score.txt", ios::in | ios::binary);
    	if (!myFile) {
    		cout << "score.txt can't open!" << endl;
    		abort();
    	}
    	int count;
    	myFile.seekg(0);
    	myFile >> count;
    	for (int i = 0; i <= count; i++) {
    		myFile >> stu[i].class_0 >> stu[i].num       >> stu[i].name 
    			   >> stu[i].elec    >> stu[i].c_program >> stu[i].media 
    			   >> stu[i].english >> stu[i].math      >> stu[i].sport 
    			   >> stu[i].polity  >> stu[i].average;
    	}
    	myFile.close();
    	return count;
    }
    
    void Input(Student stu[]) {
    	system("cls");
    	int i = 0;
    	int flag;
    	char sign = '0';
    	cout << endl<<"======>>    请输入学生成绩    <<======"<<endl;
    	while (sign != 'n' && sign != 'N') {
    		cout << "班级:";
    		cin >> stu[i].class_0;
    	loop:
    		cout << "学号:";
    		cin >> stu[i].num;
    		int c = 0;
    		while (c < i) {
    			c++;
    			if (stu[i].num == stu[i - c].num) {
    				cout << "您输入的学号已存在!请重新输入。" << endl;
    				goto loop;
    			}
    		}
    		cout << "姓名:";
    		cin >> stu[i].name;
    		do {
    			flag = 0;
    			cout << "电子技术成绩:";
    			cin >> stu[i].elec;
    			if (stu[i].elec > 100 || stu[i].elec < 1) {
    				cout << " 对不起,请输入1-100之间的数字!!\n";
    			}
    			else {
    				flag = 1;
    			}
    		} while (flag == 0);
    		do {
    			flag = 0;
    			cout << "C++程序设计成绩:";
    			cin >> stu[i].c_program;
    			if (stu[i].c_program > 100 || stu[i].c_program < 1) {
    				cout << " 对不起,请输入1-100之间的数字!!\n";
    			}
    			else {
    				flag = 1;
    			}
    		} while (flag == 0);
    		do {
    			flag = 0;
    			cout << "多媒体技术成绩:";
    			cin >> stu[i].media;
    			if (stu[i].media > 100 || stu[i].media < 1) {
    				cout << " 对不起,请输入1-100之间的数字!!\n";
    			}
    			else {
    				flag = 1;
    			}
    		} while (flag == 0);
    		do {
    			flag = 0;
    			cout << "大学英语成绩:";
    			cin >> stu[i].english;
    			if (stu[i].english > 100 || stu[i].english < 1) {
    				cout << " 对不起,请输入1-100之间的数字!!\n";
    			}
    			else {
    				flag = 1;
    			}
    		} while (flag == 0);
    		do {
    			flag = 0;
    			cout << "高等数学成绩:";
    			cin >> stu[i].math;
    			if (stu[i].math > 100 || stu[i].math < 1) {
    				cout << " 对不起,请输入1-100之间的数字!!\n";
    			}
    			else {
    				flag = 1;
    			}
    		} while (flag == 0);
    		do {
    			flag = 0;
    			cout << "大学体育成绩:";
    			cin >> stu[i].sport;
    			if (stu[i].sport > 100 || stu[i].sport < 1) {
    				cout << " 对不起,请输入1-100之间的数字!!\n";
    			}
    			else {
    				flag = 1;
    			}
    		} while (flag == 0);
    		do {
    			flag = 0;
    			cout << "马克思主义基本原理成绩:";
    			cin >> stu[i].polity;
    			if (stu[i].polity > 100 || stu[i].polity < 1) {
    				cout << " 对不起,请输入1-100之间的数字!!\n";
    			}
    			else {
    				flag = 1;
    			}
    		} while (flag == 0);
    		stu[i].average = (stu[i].elec + stu[i].c_program + stu[i].media + stu[i].english + stu[i].math +
    			stu[i].sport + stu[i].polity) / 7;
    		cout << " 平均分为:" << stu[i].average<<endl;
    		cout << "======>>    提示:是否继续写入学生成绩 ?(y/n)";
    		cin >> sign;
    		i++;
    	}
    	Write(stu, i);
    }
    
    void Statistic(Student stu[]) {
    	system("cls");
    	int n = Read(stu);
    	cout << endl << "======>>    输出学生统计数据    <<======\n" << endl;
    	cout << "---------------------------------------" << endl;
    	cout << "班级" << "\t" << "学号" << "\t" << "姓名" << "\t" << "平均分" << endl;
    	cout << "---------------------------------------" << endl;
    	for (int i = 0; i < n; i++)
    		cout << stu[i].class_0 << "\t" << stu[i].num << "\t" << stu[i].name << "\t" << stu[i].average << endl;
    	cout << "---------------------------------------" << endl;
    	system("pause");
    }
    
    void Lookup(Student stu[]) {
    	system("cls");
    	int n = Read(stu);
    	int s;
    	int i = 0;
    	cout << endl << "======>>    查找学生成绩    <<======" << endl;
    	cout << "请输入要查找学生的学号:";
    	cin >> s;
    	while ((stu[i].num - s) != 0 && i < n)i++;
    	if (i == n) {
    		cout << "======>>    对不起,无法找到该学生......    <<======" << endl;
    	}
    	else {
    		cout << "----------------------------" << endl;
    		cout << "班级:" << stu[i].class_0 << endl;
    		cout << "学号:" << stu[i].num << endl;
    		cout << "姓名:" << stu[i].name << endl;
    		cout << "电子技术:" << stu[i].elec << endl;
    		cout << "C++程序设计:" << stu[i].c_program << endl;
    		cout << "多媒体技术:" << stu[i].media << endl;
    		cout << "大学英语:" << stu[i].english << endl;
    		cout << "高等数学:" << stu[i].math << endl;
    		cout << "大学体育:" << stu[i].sport << endl;
    		cout << "马克思主义基本原理:" << stu[i].polity << endl;
    		cout << "平均分:" << stu[i].average << endl;
    	}
    }
    
    void Modify(Student stu[]) {
    	system("cls");
    	int n = Read(stu);
    	int s;
    	int i = 0;
    	cout << endl << "======>>    修改学生成绩    <<======" << endl;
    	cout << "请输入要修改成绩学生的学号:";
    	cin >> s;
    	while ((stu[i].num - s) != 0 && i < n)i++;
    	if (i == n) {
    		cout << "======>>    对不起,无法找到该学生......    <<======" << endl;
    	}
    	else {
    		cout << "------------------------------------------------------------------------------------" << endl;
    		cout << "班级" << "\t" << "学号"  << "\t" << "姓名" << "\t"
    			 << "电子" << "\t" << "C++"  << "\t" << "多媒体" << "\t"
    			 << "英语" << "\t" << "数学"  << "\t" << "体育" << "\t"
    			 << "政治" << "\t" << "平均分" << endl;
    		cout << "------------------------------------------------------------------------------------" << endl;
    		cout << stu[i].class_0 << "\t" << stu[i].num       << "\t" << stu[i].name  << "\t"
    			 << stu[i].elec    << "\t" << stu[i].c_program << "\t" << stu[i].media << "\t"
    			 << stu[i].english << "\t" << stu[i].math      << "\t" << stu[i].sport << "\t"
    			 << stu[i].polity  << "\t" << stu[i].average   << endl;
    		cout << endl << "请重新输入该学生成绩: " << endl;
    		cout << "电子技术成绩:";
    		cin >> stu[i].elec;
    		cout << "C++成绩:";
    		cin >> stu[i].c_program;
    		cout << "多媒体技术成绩:";
    		cin >> stu[i].media;
    		cout << "大学英语成绩:";
    		cin >> stu[i].english;
    		cout << "高等数学成绩:";
    		cin >> stu[i].math;
    		cout << "大学体育成绩:";
    		cin >> stu[i].sport;
    		cout << "马克思主义基本原理成绩:";
    		cin >> stu[i].polity;
    		stu[i].average = (stu[i].elec + stu[i].c_program + stu[i].media +
    			stu[i].english + stu[i].math + stu[i].sport + stu[i].polity) / 7;
    		cout << "平均分:" << stu[i].average << endl;
    
    		char c;
    		cout << "======>>    是否保存数据 ?(y/n)";
    		cin >> c;
    		if (c != 'n' && c != 'N')
    			Write(stu, n);
    	}
    }
    
    void Delete(Student stu[]) {
    	system("cls");
    	int n = Read(stu);
    	int s;
    	int i = 0, j ;
    	cout << endl << "======>>    删除学生成绩    <<======" << endl;
    	cout << "请输入要删除的学生的学号:";
    	cin >> s;
    	while ((stu[i].num - s) != 0 && i < n)i++;
    	if (i == n) {
    		cout << "======>>    对不起,无法找到该学生......    <<======" << endl;
    	}
    	else {
    		for (j = i; j < n - 1; j++) {
    			strcpy(stu[j].class_0,stu[j + 1].class_0);
    			stu[j].num = stu[j + 1].num;
    			strcpy(stu[j].name, stu[j + 1].name);
    			stu[j].elec = stu[j + 1].elec;
    			stu[j].c_program = stu[j + 1].c_program;
    			stu[j].media = stu[j + 1].media;
    			stu[j].english = stu[j + 1].english;
    			stu[j].math = stu[j + 1].math;
    			stu[j].sport = stu[j + 1].sport;
    			stu[j].polity = stu[j + 1].polity;
    			stu[j].average = stu[j + 1].average;
    		}
    		cout << "======>>    提示:已成功删除!" << endl;
    	}
    	Write(stu, n - 1);
    }
    
    void Insert(Student stu[]) {
    	system("cls");
    	int n = Read(stu);
    	char s='0';
    	cout << endl << "=======>>    增加学生成绩    <<========" << endl;
    	while (s != 'n' && s != 'N') {
    		cout << "班级:";
    		cin >> stu[n].class_0;
    		cout << "学号:";
    		cin >> stu[n].num;
    		cout << "姓名:";
    		cin >> stu[n].name;
    		cout << "电子技术成绩:";
    		cin >> stu[n].elec;
    		cout << "C++成绩:";
    		cin >> stu[n].c_program;
    		cout << "多媒体技术成绩:";
    		cin >> stu[n].media;
    		cout << "大学英语成绩:";
    		cin >> stu[n].english;
    		cout << "高等数学成绩:";
    		cin >> stu[n].math;
    		cout << "大学体育成绩:";
    		cin >> stu[n].sport;
    		cout << "马克思主义基本原理成绩:";
    		cin >> stu[n].polity;
    		stu[n].average = (stu[n].elec + stu[n].c_program + stu[n].media +
    			stu[n].english + stu[n].math + stu[n].sport + stu[n].polity) / 7;
    		cout << "平均分:" << stu[n].average << endl;
    		n++;
    		cout << "======>>    是否继续插入(y/n)";
    		cin >> s;
    	}
    	Write(stu, n);
    }
    
    void Sort(Student stu[]) {
    	system("cls");
    	int i, j, k;
    	float s;
    	char t[20];
    	cout << endl << "======>>    降序排列    <<======" << endl;
    	int n = Read(stu);
    	for (i = 0; i < n-1; i++) {
    		for (j = 0; j < n - 1; j++) {
    			if (stu[j].average < stu[j + 1].average) {
    				//交换课程
    				strcpy(t, stu[j + 1].class_0);
    				strcpy(stu[j + 1].class_0, stu[j].class_0);
    				strcpy(stu[j].class_0, t);
    				//num
    				k = stu[j + 1].num;
    				stu[j + 1].num = stu[j].num;
    				stu[j].num = k;
    
    				//name
    				strcpy(t, stu[j + 1].name);
    				strcpy(stu[j + 1].name, stu[j].name);
    				strcpy(stu[j].name, t);
    				//elec
    				s = stu[j + 1].elec;
    				stu[j + 1].elec = stu[j].elec;
    				stu[j].elec = s;
    				//c_program
    				s = stu[j + 1].c_program;
    				stu[j + 1].c_program = stu[j].c_program;
    				stu[j].c_program = s;
    				//media
    				s = stu[j + 1].media;
    				stu[j + 1].media = stu[j].media;
    				stu[j].media = s;
    				//english
    				s = stu[j + 1].english;
    				stu[j + 1].english = stu[j].english;
    				stu[j].english = s;
    				//math
    				s = stu[j + 1].math;
    				stu[j + 1].math = stu[j].math;
    				stu[j].math = s;
    				//sport
    				s = stu[j + 1].sport;
    				stu[j + 1].sport = stu[j].sport;
    				stu[j].sport = s;
    				//polity
    				s = stu[j + 1].polity;
    				stu[j + 1].polity = stu[j].polity;
    				stu[j].polity = s;
    				//average
    				s = stu[j + 1].average;
    				stu[j + 1].average = stu[j].average;
    				stu[j].average = s;
    			}
    		}
    	}
    	cout << "------------------------------------------------------------------------------------" << endl;
    	cout << "班级" << "\t" << "学号" << "\t" << "姓名" << "\t"
    		 << "电子" << "\t" << "C++" << "\t" << "多媒体" << "\t"
    		 << "英语" << "\t" << "数学" << "\t" << "体育" << "\t"
    		 << "政治" << "\t" << "平均分" << endl;
    	cout << "------------------------------------------------------------------------------------" << endl;
    	for (int i = 0; i < n; i++) {
    		stu[i].order = i + 1;
    		cout << stu[i].class_0 << "\t" << stu[i].num       << "\t" << stu[i].name << "\t"
    			 << stu[i].elec    << "\t" << stu[i].c_program << "\t" << stu[i].media << "\t"
    			 << stu[i].english << "\t" << stu[i].math      << "\t" << stu[i].sport << "\t"
    			 << stu[i].polity  << "\t" << stu[i].average   << endl;
    	}
    	Write(stu, n);
    }
    
    void Output(Student stu[]) {
    	system("cls");
    	int n = Read(stu);
    	cout << endl << "======>>    显示全部学生成绩    <<======" << endl;
    	if (!stu) {
    		cout << "没有记录";
    	}
    	else {
    		cout << "------------------------------------------------------------------------------------" << endl;
    		cout << "班级" << "\t" << "学号"  << "\t" << "姓名"  << "\t" 
    			 << "电子" << "\t" << "C++"  << "\t" << "多媒体" << "\t" 
    			 << "英语" << "\t" << "数学"  << "\t" << "体育"  << "\t" 
    			 << "政治" << "\t" << "平均分" << endl;
    		cout << "------------------------------------------------------------------------------------" << endl;
    		for (int i = 0; i < n; i++) {
    			cout << stu[i].class_0 << "\t" << stu[i].num       << "\t" << stu[i].name  << "\t"
    				 << stu[i].elec    << "\t" << stu[i].c_program << "\t" << stu[i].media << "\t"
    				 << stu[i].english << "\t" << stu[i].math      << "\t" << stu[i].sport << "\t"
    				 << stu[i].polity  << "\t" << stu[i].average   << endl;
    		}
    		cout << "------------------------------------------------------------------------------------" << endl;
    	}
    }
    
    int menu() {
    	char c;
    	do {
    		system("cls");
    		cout << "******************************************************" << endl;
    		cout << "----------------欢迎使用学生成绩管理系统---------------" << endl;
    		cout << "    *          【1】输入学生成绩                  *    " << endl;
    		cout << "    *          【2】显示统计数据                  *    " << endl;
    		cout << "    *          【3】查找学生成绩                  *    " << endl;
    		cout << "    *          【4】修改学生成绩                  *    " << endl;
    		cout << "    *          【5】删除学生成绩                  *    " << endl;
    		cout << "    *          【6】插入学生成绩                  *    " << endl;
    		cout << "    *          【7】按平均分排列                  *    " << endl;
    		cout << "    *          【8】显示学生成绩                  *    " << endl;
    		cout << "    *          【0】退出管理系统                  *    " << endl;
    		cout << "******************************************************" << endl;
    		cout << "请选择您的操作 (0-8):" << endl;
    		c = getchar();
    	} while (c < '0' || c > '8');
    	return (c - '0');
    }
    
    int main() {
    	for (;;) {
    		switch (menu()) {
    			case 1:
    				Input(stu);
    				break;
    			case 2:
    				Statistic(stu);
    				break;
    			case 3:
    				Lookup(stu);
    				system("pause");
    				break;
    			case 4:
    				Modify(stu);
    				system("pause");
    				break;
    			case 5:
    				Delete(stu);
    				system("pause");
    				break;
    			case 6:
    				Insert(stu);
    				system("pause");
    				break;
    			case 7:
    				Sort(stu);
    				system("pause");
    				break;
    			case 8:
    				Output(stu);
    				system("pause");
    				break;
    			case 0:
    				cout << endl << "================感谢您使用学生成绩管理系统==============\n" << endl;
    				exit(0);
    		}
    	}
    	return 0;
    }

        该代码在visual studio 2019上运行没有问题,不知道在别的IDE中有没有问题,这是一个纯c++实现的,没有参杂c的内容,但是如果用c来实现,也基本就是这个样子,就是前面的Student类换成结构体struct,输入输出改为scanf,printf ,文件读写改为c的,其他的没有太大的改变。

        如下所示,当我们一开始运行这个程序,没有录入学生成绩,直接点击【8】显示学生成绩,它会提示失败,并抛出错误:

        

        这就是前面提到的那个问题,我们需要手动创建一个score.txt文件并写入相关记录,文件格式以及数据在前面你已经提到,或者我们点击【1】输入学生成绩,创建这个文件也是可以的,后续反复运行这个程序也不会报错了。 

    展开全文
  • 微机原理课程设计汇本之学生成绩管理系统设计.doc
  • 阶段 1.1 成绩管理系统实体关系设计 一实验目的和要求 1熟练掌握实体关系设计的方法 2 通过需求分析结果掌握 E-R 图 二实验内容和原理 实体关系设计是在需求分析的一个环节过程 在这一过程中产生 E-R 图该图由实体 ...
  • 该文件是数据库课程设计学生成绩管理系统登录界面及学生教师界面的切换,
  • 微机原理课程设计_学生成绩管理系统微机原理课程设计_学生成绩管理系统
  • 你所看到的程序为周峰版微机原理与接口技术第四章31题程序汇编语言
  • 标题:python学生成绩管理系统详细源码 详细要求: 一、实验目的 1.熟悉Python3.X和Pycharm的运行环境 2.掌握函数、模块和面向对象编程思想。 二、实验环境 计算机及Python3.X和Pycharm软件。 三、实验内容与要求 1...

    一、实验目的

    1.熟悉Python3.X和Pycharm的运行环境
    2.掌握函数、模块和面向对象编程思想。
    

    二、实验环境

    计算机及Python3.X和Pycharm软件。
    

    三、实验内容与要求
    1、创建4个.py模块,在一个包内,模块命名分别为main.py,ui.py,model.py,bll.py。
    2、(1)实现学生管理系统在控制台的输出显示界面如图1所示。
    在这里插入图片描述
    图1 显示界面
    (2)在model.py模块中建立学生类,其中包含的属性有name,age,score,id。
    (3)在bll.py模块中建立学生管理业务逻辑类,即在此模块中实现增加、显示、删除、修改和成绩排序等功能。
    (4)在ui.py模块中建立学生管理显示界面。
    (5)在main.py模块中实现建立if name == “main”:
    分析:界面使用控制台输出显示
    1.识别对象:界面视图类、逻辑控制类、数据模型类
    2.分配职责:
    界面视图类:负责处理界面逻辑,比如显示菜单,获取输入,显示结果等。
    逻辑控制类:负责存储学生信息,处理业务逻辑。比如添加、删除等
    数据模型类:定义需要处理的数据类型。比如学生信息。
    3.建立交互:
    界面视图对象<---->数据模型对象<---->逻辑控制对象
    设计:
    数据模型类:StudentModel
    属性:编号id,姓名 name,年龄 age,成绩 score
    逻辑控制类:StudentManagerController
    属性:学生列表stu_list
    行为:添加学生add_student,删除学生remove_student,修改学生update_student,根据成绩排序order_by_score。
    界面视图类:StudentManagerView
    属性:逻辑控制对象manager
    行为:显示菜单display_menu,选择菜单项select_menu_item
    新增内容:
    1、对学生的信息放入到文本中操作。
    2、在写的程序中,要添加异常处理。例如,成绩输错了没?学号是否具有唯一性?自己去思考。。。。

    注:源代码需自行分模块!!!

    #main.py
    import ui
    import model
    import os
    if __name__=='__main__':    
        while 1 :
            a=ui.UI_CLASS()
            a.UI()
            a.Select_UI()
            p = input('按任意键进行下一步操作')
            i = os.system('cls')
        pass
       #model.py
       class StudentModel(object):
        def __init__(self,name,age,score,id):
            self.name = name
            self.age = age
            self.score = score
            self.id = id
      #ui.py
     import bll
    import sys
    class UI_CLASS():
        Student_s = []
        def __init__(self):
            pass
        def UI(self):
            print('-----------------------')
            print('1) 添加学生')
            print('2) 显示学生')
            print('3) 删除学生')
            print('4) 修改学生')
            print('5) 按照程序降序排列')
            print('-----------------------')
        def Select_UI(self):
            b = bll.manage_student()
            c = int(input("请选择:"))
            if c == 1:
                b.AppendStudent(self.Student_s)
            elif c == 2:
                b.PrintStudent(self.Student_s)
            elif c == 3:
                b.DelStudent(self.Student_s)
            elif c == 4:
                b.AlterStudent(self.Student_s)
            elif c == 5:
                b.SortStudent(self.Student_s)
            else:
                print('结束进程')
                sys.exit(0)
          #bll.py
          import model
    class manage_student():
        def __init__(self):
            pass
        @classmethod
        def AppendStudent(self, Student_s):
            # 名字
            name = input('姓名:')
            # 获取年龄
            def get_age():
                age = int(input('年龄(1-140):'))
                if age in range(1, 141):
                    # if age>0 or age<=140:
                    return age
                raise ValueError  # 抛出异常(传入无效的参数)
            while True:
                try:
                    age = get_age()
                    # print('用户输入的年龄是:', age)
                    break
                except ValueError:  # 接收抛出的异常
                    print('用户输入的年龄不在1-140之间,获取年龄失败!')
            # 获取成绩
            def get_score():
                score = int(input('成绩(0-100):'))
                if score in range(0, 101):
                    return score
                raise ValueError  # 抛出异常(传入无效的参数)
            while True:
                try:
                    score = get_score()
                    break
                except ValueError:  # 接收抛出的异常
                    print('用户输入的成绩不在0-100之间,获取成绩失败!')
            # 获取唯一学号
            def get_id():
                id = input('请输入唯一学号:')
                if len(Student_s) == 0:
                    return id
                else:
                    for i in range(len(Student_s)):
                        if id != Student_s[i].id:
                            return id
                        else:
                            raise ValueError  # 抛出异常
            while True:
                try:
                    id = get_id()
                    break
                except ValueError:  # 接收抛出的异常
                    print('用户输入的学号不唯一,获取学号失败!')
            NewStudent = model.StudentModel(name, age, score, id)
            Student_s.append(NewStudent)
            f = open('test.txt', 'w')
            f.write('  姓名  年龄  分数  学号')
            f.write('\n')
            for i in range(len(Student_s)):
                f.write(str('%d. %s  %s   %s   %s' % (
                    i + 1, Student_s[i].name, Student_s[i].age, Student_s[i].score, Student_s[i].id)))
                f.write('\n')
            f.close()
        def PrintStudent(self, Student_s):
            # print('   姓名 年龄 分数 学号')
            # for i in range(len(Student_s)):
            #     print('%d. %s  %s  %s  %s' % (i + 1, Student_s[i].name, Student_s[i].age, Student_s[i].score, Student_s[i].id))
            f = open('test.txt', 'r')
            print(f.read())
            f.close()
        def DelStudent(self, Student_s):
            flag = 0
            self.PrintStudent(Student_s)
            name = input('请输入要删除的学生名字:')
            for i in range(len(Student_s)):
                if name == Student_s[i].name:
                    del Student_s[i]
                    f = open('test.txt', 'w')
                    f.write('  姓名  年龄  分数  学号')
                    f.write('\n')
                    for i in range(len(Student_s)):
                        f.write(str('%d. %s  %s   %s   %s' % (
                            i + 1, Student_s[i].name, Student_s[i].age, Student_s[i].score, Student_s[i].id)))
                        f.write('\n')
                    flag = 1
                    f.close()
                    break
            if flag == 0:
                print('查无此人')
        def AlterStudent(self, Student_s):
            self.PrintStudent(Student_s)
            i = int(input('请选择修改对象(输入前方编号):'))
            if i > len(Student_s):
                print('错误编号')
            else:
                i -= 1
                print('1.姓名  2.年龄  3.分数  4.学号')
                j = int(input('请选择:'))
                if j == 1:
                    Student_s[i].name = input('请输入姓名:')
                elif j == 2:
                    # Student_s[i].age = input('请输入年龄:')
                    # 修改年龄
                    def get_age():
                        age = int(input('请输入年龄(1-140):'))
                        if age in range(1, 141):
                            # if age>0 or age<=140:
                            return age
                        raise ValueError  # 抛出异常(传入无效的参数)
                    while True:
                        try:
                            Student_s[i].age = get_age()
                            # print('用户输入的年龄是:', age)
                            break
                        except ValueError:  # 接收抛出的异常
                            print('用户输入的年龄不在1-140之间,获取年龄失败!')
                elif j == 3:
                    # Student_s[i].score = input('请输入分数:')
                    # 修改成绩
                    def get_score():
                        score = int(input('亲输入分数(0-100):'))
                        if score in range(0, 101):
                            return score
                        raise ValueError  # 抛出异常(传入无效的参数)
                    while True:
                        try:
                            Student_s[i].score = get_score()
                            break
                        except ValueError:  # 接收抛出的异常
                            print('用户输入的成绩不在0-100之间,获取成绩失败!')
                elif j == 4:
                    Student_s[i].id = input('请输入学号:')
                else:
                    print('输入有误')
            f = open('test.txt', 'w')
            f.write('  姓名  年龄  分数  学号')
            f.write('\n')
            for i in range(len(Student_s)):
                f.write(str('%d. %s  %s   %s   %s' % (
                    i + 1, Student_s[i].name, Student_s[i].age, Student_s[i].score, Student_s[i].id)))
                f.write('\n')
            f.close()
        def SortStudent(self, Student_s):
            for i in range(1, len(Student_s)):
                for j in range(0, len(Student_s) - i):
                    if Student_s[j].score < Student_s[j + 1].score:
                        t=Student_s[j]
                        Student_s[j] = Student_s[j + 1]
                        Student_s[j+1]=t
            print('排序成功')
            f = open('test.txt', 'w')
            f.write('  姓名  年龄  分数  学号')
            f.write('\n')
            for i in range(len(Student_s)):
                f.write(str('%d. %s  %s   %s   %s' % (
                    i + 1, Student_s[i].name, Student_s[i].age, Student_s[i].score, Student_s[i].id)))
                f.write('\n')
            f.close()
    

    注:本页源码,为实验报告所编写,有许多优化等问题,欢迎大家指正。另外,第一次编写csdn,望不喜勿喷。

    展开全文
  • Java学生成绩管理系统实验报告

    千次阅读 2021-03-08 06:12:55
    实验名称 实验类型 实验编号学生成绩管理系统 □验证 实验学时 √综合 1 分组号指导教师 8+10 1 实验日期 实验时间 实验地点 6A-413一、 实验目的和要求(1) 掌握 java 的基本数据类型;掌握数组的定义和使用; (2) ...

    实验名称 实验类型 实验编号

    学生成绩管理系统 □验证 实验学时 √综合 1 分组号

    指导教师 8+10 1 实验日期 实验时间 实验地点 6A-413

    一、 实验目的和要求

    (1) 掌握 java 的基本数据类型;掌握数组的定义和使用; (2) 掌握 java 语言中的控制结构的使用; (3) 掌握 java 语言中的类的定义与使用; (4) 掌握 java 语言中继承、多态、接口、抽象类、异常处理等; (5) 掌握图形用户界面设计技术;熟练掌握组件、布局管理器、容器等的使用;掌握菜单技术的 使用、掌握 java 语言中的事件处理。 (6) 掌握 java 语言中的各种文件操作, 及以字符为单位、 以字节为单位的数据流操作和随机文件 的操作;掌握对象的串行化。

    二、实验环境(实验设备)

    硬件: 软件: 微型计算机 P4 Windows XP+JCreator3.5 及以上或 NetBeans

    三、实验原理及内容

    实验题目:学生成绩管理软件设计 内容: 学生成绩管理主要包括如下内容: 1)学生档案管理 学生档案信息包括学号、姓名、性别、年级、专业、政治面貌 2)课程管理 课程信息包括课程编号、课程名称、学时、学分、课程性质、开课学期 3)成绩管理 成绩信息包括学号、课程编号、成绩 请根据以上要求编写程序,以图形用户界面菜单形式实现各功能。 使用的菜单有: 数据录入:包含学生档案、学生成绩、课程信息三个菜单项 修改:包括对学生成绩、档案、课程等信息的修改 查询:包括对学生成绩、档案、课程信息的查询。 统计:包括年级人数、某专业人数、修某课程人数、某学生通过的学分数等功能。 显示:也即打印功能,主要是报表打印,包括学生档案表、成绩表、课程表等。

    418c9f4934e2701d1c8dd7bf03f94b8f.png

    展开全文
  • 学生成绩管理系统,全面运用数据库原理课程所学知识,从系统需求分析着手,进行数据库的概念设计、逻辑设计、物理设计、系统的总体设计和模块设计、编程、调试,并在各个环节中提供相关的文档。本系统主要用于学校...
  • 学生成绩管理系统.zip

    2020-09-23 13:05:53
    学生成绩管理系统原理和算法是必经之路,是小菜鸡上传的第一个代码,是大学的期末课设,注释很详细,而且代码很健全,可以私聊博主,每天都在~
  • 课程设计----学生成绩档案管理系统设计 微机原理与接口技术 用汇编语言编写程序,设计一个学生成绩档案管理系统。要求该系统具有如下6个的基本功能:1输入;2 显示;3查找;4修改;5 排序;6退出。界面以菜单形式...
  • 数据库原理及Oracle开发课程设计 题 目 选课管理系统 系 (部) 电信系 班 级 计本一班 姓 名 耿榕 学 号 2012020198 指导教师 黄硕 2014年 6 月9日 选课管理系统 选课管理系统 数据库原理及Oracle开发 课程设计任务书...
  • 【数据库原理】综合设计报告学生成绩管理系统.doc
  • 这是我在大学上数据库课的时候老师布置的作业。
  • WEB课设之学生成绩管理系统 一、设计内容 学校每年都会有学生基本信息变动,也会举行期中期末考试。如何有效地管理这些学生的基本信息和成绩,帮助学校和老师掌握学生的基本情况,这就是学生成绩管理系统需要完成...
  • 一个简单易懂的学生信息管理系统,源代码非常简单,包含全部源代码和详细注释,已经调试好,没有任何问题直接运行就OK。
  • PAGE / NUMPAGES 实验六 学生成绩管理系统设计实验 一实验目的 1熟悉汇编语言程序结构 2熟悉INT 21H的文件操作功能调用 3熟悉INT 21H的19号功能和INT 10H常用功能的使用方法 4掌握多子程序复杂问题程序设计方法 5...
  • 验 报 告 实 验 题 目 学生成绩管理系统 年 级 专 业09级计算机科学与技术2班 小 组 成 员 刘喜江 李红飞 杨国威 指 导 教 师 许 薇 完 成 日 期 2011年11月25日 目 录 TOC \o "1-3" \h \u 15170 一数据库功能设计 ...
  • 阶段 1.1 成绩管理系统实体关系设计 一实验目的和要求 1熟练掌握实体关系设计的方法 2通过需求分析结果掌握图 二实验内容和原理 实体关系设计是在需求分析的一个环节过程在这一过程中产生图该图由实体属 性和联系三...
  • (1)设计 (2)数据 属性依次为:课程号、课程名、先修课课程号、学分 主键为课程号 Student表: (1)设计 (2)数据 属性依次为:学号、姓名、性别、年龄、所在系系名 主键为学号 SC表:表示学生选课关系 (1...
  • shell编程实验——学生成绩管理系统
  • 该源程序是数据结构的学生成绩管理系统的源代码。里面功能模块比较齐全。
  • 完整的数据库原理课程设计,包含报告、代码、数据库文件、日志文件等
  • 基于Python的学生成绩管理系统

    千次阅读 多人点赞 2021-08-05 23:04:34
    将现代的计算机技术和传统的学生成绩管理工作相结合,并按照高校学生成绩管理工作流程,设计完成一套功能较为完备的高校学生成绩系统。为了使系统在高校学生成绩管理工作中发挥更大的作用,实现工作过程的计算机化,...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 11,561
精华内容 4,624
关键字:

学生成绩管理系统设计原理