学生成绩管理系统(C语言版)「建议收藏」

学生成绩管理系统(C语言版)「建议收藏」大一上学期实训项目总结(学生成绩管理系统)大一刚接触这个计算机专业的相关知识,就觉得这个专业很有趣。最先接触的编程语言就是C语言,想必大多数人都是如此吧。我们这个学期末,也就是期末考试结束后,开始这个实训。我也是第一次听说实训这个东西,当然可能这个实训也主要针对我们计算机专业的学生。我们这次实训历时5天,是由公司请来的专业人员给我们进行指导的。前面几天时进行C语言基础知识的复习与巩固,后面两天就是给每个组时间,进行实训项目的制作。我们组选择的是学生成绩管理系统,这个也是比较常见的项目,有些组选择的是贪吃

大家好,又见面了,我是你们的朋友全栈君。

大一上学期实训项目总结(学生成绩管理系统)

大一刚接触这个计算机专业的相关知识,就觉得这个专业很有趣。最先接触的编程语言就是C语言,想必大多数人都是如此吧。我们这个学期末,也就是期末考试结束后,开始这个实训。我也是第一次听说实训这个东西,当然可能这个实训也主要针对我们计算机专业的学生。
我们这次实训历时5天,是由公司请来的专业人员给我们进行指导的。前面几天时进行C语言基础知识的复习与巩固,后面两天就是给每个组时间,进行实训项目的制作。我们组选择的是学生成绩管理系统,这个也是比较常见的项目,有些组选择的是贪吃蛇等等。
下面给图片展示我们组的实训项目图片:
1 登录界面(确实挺简陋的)
在这里插入图片描述
2 功能界面
在这里插入图片描述
3 录入学生信息图片

在这里插入图片描述

4 查询信息示例图片
在这里插入图片描述
5 显示学生信息示例图片
在这里插入图片描述
6 退出界面
在这里插入图片描述
最后上代码,这是我们组这几天的实训成果,希望点个赞,谢谢啦。

#include<stdio.h>
#include<stdlib.h>
#include<conio.h>
#include<dos.h>
#include<string.h>
#define LEN sizeof(struct student)
#define FORMAT "%-8d%-15s%-12.1lf%-12.1lf%-12.1lf%-12.1lf%-12.1f\n"
#define DATA stu[i].num,stu[i].name,stu[i].cyy,stu[i].dlfx,stu[i].gs,stu[i].yy,stu[i].jd



struct student
{ 
   
	int num;
	char name[15];
	double cyy;
	double dlfx;
	double gs;
	double yy;
	double jd;
};



struct student stu[51];
void denglujiemian();
void menu1();
void menu2();
void in();
void search();
void del();
void modify();
void insert();
void order();
void total();
void show();
void flunk();
void denglujiemian();

int main()
{ 
   
	system("color e3\n");
	int n;
	char w;
	printf("***欢***迎***进***入***学***生***成***绩***管***理***系***统***");
	printf("请选择进入模式:\n如果选择老师模式请输入“A”,选择学生模式请按“B”。");
	scanf("%c",&w);
	if(w=='A')
	{ 
   
  	menu2();
  	scanf("%d",&n);
  	while(n)
  	{ 
   
	  	switch(n)
     	{ 
   
		 	case 1: in();break;
       		case 2: search();break;
       		case 3: del();break;
       		case 4: modify();break;
       		case 5: insert();break;
       		case 6: order();break;
       		case 7: total();break;
       		case 8: flunk();break;
	   		case 9: show();break;
       		default:break;
     	}
    printf("输入任意键将返回主菜单\n");
    getch();
    menu2();
    scanf("%d",&n);
  	}
	}
  	else if(w=='B')
    { 
   
      menu1();
      scanf("%d",&n);
  	while(n)
  	{ 
   
	  	switch(n)
     	{ 
   
       		case 1: search();break;
       		case 2: order();break;
       		case 3: total();break;
       		case 4: flunk();break;
	   		case 5: show();break;
       		default:break;
     	}
    printf("输入任意键将返回主菜单\n");
    getch();
    menu1();
    scanf("%d",&n);
    }
    }
    else
    { 
   
        printf("错误!!!请重新输入");
    }


}



void in()
{ 
   
	int i,m=0;
  	char ch[2];
  	FILE *fp;
  	if((fp=fopen("data1.txt","a+"))==NULL)
  	{ 
   
	  	printf("文件不存在!\n");
	  	return;
  	}
  	while(!feof(fp))
  	{ 
   
	  	if(fread(&stu[m] ,LEN,1,fp)==1)
	  	{ 
   
		  	m++;
		}
  	}
  	fclose(fp);
  	if(m==0)
  	{ 
   
	  	printf("文件中没有记录!\n");
	}
  	else
  	{ 
   
        show();
  	}
  	if((fp=fopen("data1.txt","ab+"))==NULL)
  	{ 
   
	  	printf("文件不存在!\n");
	  	return;
 	 }


  	printf("输入学生信息(y/n):");
  	scanf("%s",ch);
	while(strcmp(ch,"Y")==0||strcmp(ch,"y")==0)
	{ 
   
    	printf("学号:");
		scanf("%d",&stu[m].num);
    	for(i=0;i<m;i++)
	    	if(stu[i].num==stu[m].num)
	    	{ 
   
	   			printf("该序号已经存在了,按任意键继续!");
	    		getch();
	    		fclose(fp);
	    		return;
	    	}
     	printf("姓名:");
	 	scanf("%s",stu[m].name);
     	printf("C语言:");
    	scanf("%lf",&stu[m].cyy);
     	printf("电路分析:");
	 	scanf("%lf",&stu[m].dlfx);
     	printf("高等数学:");
	 	scanf("%lf",&stu[m].gs);
	 	printf("大学英语:");
	 	scanf("%lf",&stu[m].yy);
     	stu[m].jd=stu[m].cyy/10-5+stu[m].dlfx/10-5+stu[m].gs/10-5+stu[m].yy/10-5;
     	if(fwrite(&stu[m],LEN,1,fp)!=1)
     	{ 
   
		 	printf("不能保存!");
		 	getch();
	 	}
     	else
	 	{ 
   
		 	printf("%s 被保存!\n",stu[m].name);
		 	m++;
	 	}
     	printf("继续?(y/n):");
     	scanf("%s",ch);
  	}
  	fclose(fp);
  	printf("OK!\n");
}




void show()
 { 
   
	FILE *fp;
  	int i,m=0;
  	fp=fopen("data1.txt","rb");
  	while(!feof(fp))
  	{ 
   
  		if(fread(&stu[m] ,LEN,1,fp)==1)
   		m++;
   	}
   	fclose(fp);
   	printf("学号 姓名 C语言 电路分析 高等数学 大学英语 总绩点\t\n");
   	for(i=0;i<m;i++)
    { 
   
	   printf(FORMAT,DATA);
    }
}



void menu2()
{ 
   
  	system("cls");
  	printf("\n\n\n\n");
  	printf("\t\t|---------------学生成绩管理系统---------------|\n");
  	printf("\t\t|\t\t\t\t\t |\n");
  	printf("\t\t|\t\t 1. 录入学生成绩\t |\n");
  	printf("\t\t|\t\t 2. 查找学生信息\t |\n");
  	printf("\t\t|\t\t 3. 删除学生信息\t |\n");
  	printf("\t\t|\t\t 4. 修改学生信息\t |\n");
 	printf("\t\t|\t\t 5. 插入学生信息\t |\n");
 	printf("\t\t|\t\t 6. 按总绩点排序\t |\n");
  	printf("\t\t|\t\t 7. 统计学生总数\t |\n");
    printf("\t\t|\t\t 8. 显示挂科学生信息\t |\n");
  	printf("\t\t|\t\t 9. 显示所有学生信息\t |\n");
    printf("\t\t|\t\t 0. 退出系统\t\t |\n");
    printf("\t\t|\t\t\t\t\t |\n");
  	printf("\t\t|----------------------------------------------|\n\n");
  	printf("\t\t\t\t\t\t\t制作团队:第二组\n");
  	printf("\t\t\t请选择(0-9):");
}
void menu1()
{ 
   
   system("cls");
  	printf("\n\n\n\n");
  	printf("\t\t|---------------学生成绩管理系统---------------|\n");
  	printf("\t\t|\t\t\t\t\t |\n");
  	printf("\t\t|\t\t 1. 查找学生信息\t |\n");
 	printf("\t\t|\t\t 2. 按总绩点排序\t |\n");
  	printf("\t\t|\t\t 3. 统计学生总数\t |\n");
    printf("\t\t|\t\t 4. 显示挂科学生信息\t |\n");
  	printf("\t\t|\t\t 5. 显示所有学生信息\t |\n");
    printf("\t\t|\t\t 0. 退出系统\t\t |\n");
    printf("\t\t|\t\t\t\t\t |\n");
  	printf("\t\t|----------------------------------------------|\n\n");
  	printf("\t\t\t\t\t\t\t制作团队:第二组\n");
  	printf("\t\t\t请选择(0-5):");
}


void order()
{ 
   
	FILE *fp;
  	struct student t;
  	int i=0,j=0,m=0;
  	if((fp=fopen("data1.txt","r+"))==NULL)
    { 
   
		printf("文件不存在!\n");
        return;
  	}
  	while(!feof(fp))
 	if(fread(&stu[m] ,LEN,1,fp)==1)
	  	m++;
  	fclose(fp);
  	if(m==0)
  	{ 
   
	  	printf("文件中没有记录!\n");
	  	return;
  	}
  	if((fp=fopen("data1.txt","wb"))==NULL)
    { 
   
	  	printf("文件不存在!\n");
	  	return;
	}
  	for(i=0;i<m-1;i++)
      for(j=i+1;j<m;j++)
        if(stu[i].jd<stu[j].jd)
        { 
   
		  	t=stu[i];stu[i]=stu[j];stu[j]=t;
		}
	if((fp=fopen("data1.txt","wb"))==NULL)
    { 
   
		printf("文件不存在!\n");
		return;
	}
  	for(i=0;i<m;i++)
      	if(fwrite(&stu[i] ,LEN,1,fp)!=1)
       	{ 
   
        	printf("%s 不能保存文件!\n");
        	getch();
      	}
  	fclose(fp);
  	printf("保存成功\n请返回选项9查看排名\n");
}




void del()
{ 
   
	FILE *fp;
  	int snum,i,j,m=0,n=0;
  	char ch[2];
  	if((fp=fopen("data1.txt","r+"))==NULL)
    { 
   
		printf("文件不存在!\n");
		return;
	}
  	while(!feof(fp))  if(fread(&stu[m],LEN,1,fp)==1) m++;
  	fclose(fp);
  	if(m==0)
  	{ 
   
	  	printf("文件中没有记录!\n");
	  	return;
  	}

  	printf("请输入学生学号");
  	scanf("%d",&snum);
    for(i=0;i<m;i++)
	 	if(snum==stu[i].num)
	   	{ 
   
     		printf("找到了这条记录,是否删除?(y/n)");
     		scanf("%s",ch);
      		if(strcmp(ch,"Y")==0||strcmp(ch,"y")==0)
      		{ 
   
	  			for(j=i;j<m;j++)
	      		stu[j]=stu[j+1];
	      		m--;
      			if((fp=fopen("data1.txt","wb"))==NULL)
     			{ 
   
				 	printf("文件不存在\n");
					return;
				}
  				for(j=0;j<m;j++)
      			if(fwrite(&stu[j] ,LEN,1,fp)!=1)
       			{ 
   
				   	printf("can not save!\n");
      				getch();
				}
  				fclose(fp);
  				printf("删除成功!\n");
      		}
      		else
            { 
   
      			printf("找到了记录,选择不删除!");
	  		}
  				break;
  		}
        else
		{ 
   
		    n++;

		}
		if(n==m)
		  	printf("没有找到记录!\n");
}


void search()
{ 
   
	FILE *fp;
  	int snum,i,m=0;
  	if((fp=fopen("data1.txt","rb"))==NULL)
     { 
   
	 	printf("文件不存在!\n");
		return;
	}
  	while(!feof(fp))
	  if(fread(&stu[m],LEN,1,fp)==1)
	  m++;
  	fclose(fp);
  	if(m==0)
	{ 
   
	  	printf("文件中没有记录!\n");
	  	return;
	}
  	printf("请输入学号:");
  	scanf("%d",&snum);
  	for(i=0;i<m;i++)
    if(snum==stu[i].num)
    { 
   
          printf("学号 姓名 C语言 电路分析 高等数学 大学英语 总绩点\t\n");
          printf(FORMAT,DATA);
	  break;
    }
  	if(i==m) printf("没有找到这名学生!\n");
}



void modify()
{ 
   
  	FILE *fp;
  	struct student t;
  	int i=0,j=0,m=0,snum;
  	if((fp=fopen("data1.txt","r+"))==NULL)
    { 
   
		printf("文件不存在!\n");
        return;
  	}
  	while(!feof(fp))
  		if(fread(&stu[m] ,LEN,1,fp)==1)
			m++;
  	if(m==0)
  	{ 
   
	  	printf("文件中没有记录!\n");
		fclose(fp);
	  	return;
  	}
  	show();
  	printf("请输入要修改的学生学号: ");
  	scanf("%d",&snum);
  	for(i=0;i<m;i++)
	  	if(snum==stu[i].num)
		  { 
   
	  		printf("找到了这名学生,可以修改他的信息!\n");
	  		printf("姓名:");
	  		scanf("%s",stu[i].name);
       	   	printf("C语言:");
	  		scanf("%lf",&stu[i].cyy);
      	    printf("电路分析:");
	  		scanf("%lf",&stu[i].dlfx);
      	    printf("高等数学:");
	  		scanf("%lf",&stu[i].gs);
			printf("大学英语:");
	  		scanf("%lf",&stu[i].yy);
	  		printf("修改成功!");
	  		stu[i].jd=(stu[i].cyy+stu[i].dlfx+stu[i].gs+stu[i].yy)/10-20;

			if((fp=fopen("data1.txt","wb"))==NULL)
     		{ 
   
		 		printf("can not open\n");
			 	return;
			}
	  		for(j=0;j<m;j++)
	  		if(fwrite(&stu[j] ,LEN,1,fp)!=1)
       		{ 
   
		   		printf("can not save!");
		   		getch();
			}
	 		fclose(fp);
	 		break;
  		}
  		if(i==m)
		  	printf("没有找到这名学生!\n");
}



void insert()
{ 
   
	FILE *fp;
  	int i,j,k,m=0,snum;
  	if((fp=fopen("data1.txt","r+"))==NULL)
    { 
   
		printf("文件不存在!\n");
		return;
	}
  	while(!feof(fp))
 		if(fread(&stu[m],LEN,1,fp)==1)
		 m++;
  	if(m==0)
	{ 
   
	  	printf("文件中没有记录!\n");
  		fclose(fp);
  		return;
  	}
  	printf("请输入要插入的位置(学号):\n");
  	scanf("%d",&snum);
  	for(i=0;i<m;i++)
	  	if(snum==stu[i].num)
		  	break;
	  	for(j=m-1;j>i;j--)
           	stu[j+1]=stu[j];
	  	printf("现在请输入要插入的学生信息.\n");
          	printf("序号:");
	  	scanf("%d",&stu[i+1].num);
	  	for(k=0;k<m;k++)
	    	if(stu[k].num==stu[m].num)
	    	{ 
   
	    		printf("该学号已经存在,按任意键继续!");
	    		getch();
	    		fclose(fp);
	    		return;
	    	}
	  	printf("姓名:");
	  	scanf("%s",stu[i+1].name);
         	 printf("C语言:");
	  	scanf("%lf",&stu[i+1].cyy);
          	printf("电路分析:");
	  	scanf("%lf",&stu[i+1].dlfx);
          	printf("高等数学:");
	  	scanf("%lf",&stu[i+1].gs);
	  		printf("大学英语:");
	  	scanf("%lf",&stu[i+1].yy);
	 	 stu[i+1].jd=(stu[i+1].cyy+stu[i+1].dlfx+stu[i+1].gs+stu[i+1].yy)/10-20;
	 	 printf("插入成功!按任意键返回主界面!");
	 	 if((fp=fopen("data1.txt","wb"))==NULL)
    	{ 
   
	 		printf("不能打开!\n");
			 return;
		}
	  	for(k=0;k<=m;k++)
	  	if(fwrite(&stu[k] ,LEN,1,fp)!=1)
       	{ 
   
		   printf("不能保存!");
		   getch();
		}
  	fclose(fp);
}



void total()
{ 
   
	FILE *fp;
  	int m=0;
  	if((fp=fopen("data1.txt","r+"))==NULL)
     { 
   
	 	printf("文件不存在!\n");
		 return;
	}
  	while(!feof(fp))
	  	if(fread(&stu[m],LEN,1,fp)==1)
		  	m++;
  	if(m==0) { 
   printf("no record!\n");fclose(fp);return;}
  	printf("这个班级一共有 %d 名学生!\n",m);
  	fclose(fp);
}


void flunk()
{ 
   
    FILE *fp;
    int i,m=0;
    fp=fopen("data1.txt","rb");
  	while(!feof(fp))
  	{ 
   
  		if(fread(&stu[m] ,LEN,1,fp)==1)
   		m++;
   	}
   	fclose(fp);
   	printf("学号 姓名 C语言 电路分析 高等数学 大学英语 总绩点\t\n");
   	for(i=0;i<m;i++)
    { 
   
        if(stu[i].dlfx<60||stu[i].cyy<60||stu[i].gs<60||stu[i].yy<60)
            printf(FORMAT,DATA);
    }
}




版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/151565.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 面试题,说说你对spring IOC和AOP的理解

    面试题,说说你对spring IOC和AOP的理解https://blog.csdn.net/s20081294/article/details/44677387在面试中,经常会问,说说你对springIOC和AOP的理解,问题很宽泛,似乎不知道从何说起。回答思路:1.先用通俗易懂的话解释下何为IOC和AOP———》2.各自的实现原理———–》3.自己的项目中如何使用以下是个人的一些总结,仅供参考。1.IOC…

    2022年6月16日
    64
  • android 的hook技术,Android Native Hook技术(一)

    android 的hook技术,Android Native Hook技术(一)原理分析ADBI是一个著名的安卓平台hook框架,基于动态库注入与inlinehook技术实现。该框架主要由2个模块构成:1)hijack负责将so注入到目标进程空间,2)libbase是注入的so本身,提供了inlinehook能力。源码目录中的example则是一个使用ADBI进行hookepoll_wait的示例。hijackhijack实现动态库注入功能,通过在目标进程插入d…

    2022年5月25日
    52
  • 员工管理系统源码_小公司服务器方案

    员工管理系统源码_小公司服务器方案简介:员工管理系统源码是一款:基于ThinkPHP框架开发的员工管理/员工信息记录系统,有增删改查功能,源码全开源,方便二次开发,搭建和使用都很简单安装教程:环境:Linux+mysql5.6+php7.2安装步骤:1.新建站点–》上传–》解压2.导入数据库文件3.修改/数据库 \Application\Home\Conf\config.php4.后台地址/home/login/index账号密码admin  www.ohbbs.cn5

    2022年9月23日
    0
  • Java开发面试常见问题总结

    最近需要面试Java开发,自己学习丢西瓜捡芝麻,学了的都忘了,所以有机会自己做个总结,摘录自各个博文以及总结。1、JAVA的跨平台原理JVA源码被编译会生成字节码文件,通过不同平台上下载的不同版本的JVM,将字节码文件翻译成对应的机器码。注意的是,跨平台的Java程序,不是JVM。JVM是使用C/C++开发的,是编译后的字节码,不能跨平台。2、JAVA中的数据类型及其各自的特点。…

    2022年4月6日
    245
  • sd0100 软件解惑

    sd0100 软件解惑今天用迅雷下点东西,发现速度最快的软件名为sd0100,当时觉得相当怪异,到google中国找了半天,也没查出是什么软件。后来进英文google,用英文找了下,发现蛛丝马迹,指向的竟然是5.9版的迅雷

    2022年7月2日
    22
  • emgucv教程(iis配置步骤)

    首先感谢qq群512782650,这是一个Emgucv爱好者创立的群,里面确实有许多爱好者。这篇博客旨在教学Emgucv3.0的安装与配置。环境:vs2015+Emgucv3.0EmguCv简介: EmguCV是.NET平台下对OpenCV图像处理库的封装。也就是OpenCV的.NET版。它运行在.NET兼容的编程语言下调用OpenCV的函数,

    2022年4月13日
    74

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号