做一个学生成绩管理系统步骤
① 教教我用SQL 2005做个《学生成绩管理系统》大概步骤
先用SQL建好数据库、接下来就是在PB里做了、先做登录界面、一个MENU、加上代码、登录界面大概就这样、这里用到的步骤很多、代码可以来问我、
② 用C语言 制作一个学生成绩管理系统 的 步骤和 做法是什么不会做啊……
我有现成的,去年我的课程设计给我一个邮箱,我发给你原代码。
③ 学生成绩管理系统怎么做
可以啊~ 我同事给我推荐了易查分,我用下来还蛮好用的,不用要代码 和服务器,你只要把你要做的查询信息 做成电子表格,导入易查分,然后易查分每个步骤都有任务向导,按照步骤完成就可以生成了!!!你试试嘛
④ 学生成绩管理系统制作步骤,登录界面怎么做啊!我想自己先做个
用word里面的邮件合并功能,首先:视图——工具栏——邮件合并,点出邮件合并工具栏版,然后在工权具栏上点击“打开数据源”,把你那个excel文件导入进来,把光标定位在姓名栏——插入域——姓名——插入——关闭,其他各科成绩也是定位在相应的科目,然后重复上面的工作,不同的是插入域不是“姓名”,而是相应各科成绩(例如:物理,数学……)。全部插入完之后,查看合并数据,如果没有问题的话,就合并到新文档,把新文档打印出来就可以了。
⑤ 如何设计一个学生成绩管理系统
这个我以前做过的,
登陆界面要分2种情况,第一个是管理员登陆
第二个是学生登陆,要设定权限
管理员可以对学生进行管理,可以对学生的成绩进行增删改查的管理。
也可以对学生的信息进行操作,可以增加科目,可以注册学生,可以编辑学生所在的班级,以及班主任姓名。
学生界面的话,这个权限就很少了,可以查询自己的各科成绩。你可以把这个查询做的丰富一点。比如按科目查询,可以做模糊查询。可以查询本次考试的最高分等等。
因为这个系统比较简单,所以没什么好说的,
数据库我用的是sqlserver,表结构你可以自己想想啊,全说明了就没意思了。
希望对你能有帮助
⑥ 学生成绩管理系统怎样做
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <conio.h>
#define N 1000
typedef struct student
{
int number;
char name[20];
int grade;
int gaoshu;
int yingyu;
int daxuewuli;
int sum;
}STUDENT;
STUDENT student[N];
int shuliang=0;
void menu();
void xiang()
{
char biao[20];
printf("\n");
printf("还需要操作么?如果需要操作请输入:yes,否则请输入:no\n");
scanf("%s",biao);
if(strcmp(biao,"yes")==0)
{
menu();
}
else if(strcmp(biao,"no")==0)
exit(0);
else
{
printf("请输入正确的字符,谢谢!\n");
xiang();
}
}
void DengJi()
{
int rs;
int i,k=1;
system("CLS");
printf("请输入需要输入几个学生信息:");
scanf("%d",&rs);
for(i=shuliang;i<shuliang+rs;i++,k++)
{
printf("请输入第%d个学生的学号:",k);
scanf("%d",&student[i].number);
printf("请输入学生的姓名:");
scanf("%s",student[i].name);
printf("请输入学生3门课的成绩:");
printf("请输入第1门课的成绩:");
scanf("%d",&student[i].gaoshu);
printf("请输入第2门课的成绩:");
scanf("%d",&student[i].yingyu);
printf("请输入第3门课的成绩:");
scanf("%d",&student[i].daxuewuli);
}
shuliang=shuliang+rs;
xiang();
}
void ShanChu()
{
char shanchuinfo[10];
system("CLS");
printf("删除全部学生信息请输入\"all\",删除指定学号的学生信息请输入\"one\"\n");
scanf("%s",shanchuinfo);
if(strcmp(shanchuinfo,"all")==0)
{
int j;
printf("你删除的学生信息如下:\n");
printf("-----------学号-------------姓名-------------高数--------------英语--------------计算机\t\n");
for(j=0;j<shuliang;j++)
printf("----%d-------%s-------%d-------%d-------%d\t\n",student[j].number,student[j].name,student[j].gaoshu,student[j].daxuewuli);
shuliang=0;
printf("删除成功\n\n");
}
else if(strcmp(shanchuinfo,"one")==0)
{
struct student *p=NULL;
int choice;
int i,j,k=0;
printf("请输入你要删除的人的学号:");
scanf("%d",&choice);
for(i=0;i<shuliang;i++)
{
if(choice==student[i].number)
{
k=1;j=i;break;
}
}
if(k)
{
if(shuliang==1)
{
p=&student[0];
free(p);
shuliang=0;
}
else
{
for(i=j;i<shuliang;i++)
{
student[i]=student[i+1];
}
shuliang=shuliang-1;
}
printf("删除成功\n\n");
}
else
{
printf("输入数据错误!\n");
}
}
xiang();
}
void LiuLan()
{
int i;
system("CLS");
if(shuliang==0)
{
printf("系统里面没有任何学生的信息!\n");
}
else
{
for(i=0;i<shuliang;i++)
{
printf("第%d个学生的学号为:%d\n",i+1,student[i].number);
printf("第%d个学生的姓名为:%s\n",i+1,student[i].name);
printf("第%d个学生的第一门课的成绩为:%d\n",i+1,student[i].gaoshu);
printf("第%d个学生的第二门课的成绩为:%d\n",i+1,student[i].yingyu);
printf("第%d个学生的第三门课的成绩为:%d\n",i+1,student[i].daxuewuli);
student[i].sum=student[i].gaoshu+student[i].yingyu+student[i].daxuewuli;
printf("第%d个学生的总成绩为:%d\n",i+1,student[i].sum);
}
}
xiang();
}
void ChaZhao()
{
int xx;
char choice,yy[20];
int i,j,k=0;
system("CLS");
if(shuliang==0)
{
printf("系统里面没有任何学生的信息!\n");
xiang();
}
printf("三种查找方式:学号,姓名,成绩\n");
printf("如果按学号查找请输1,如果按姓名查找请输2,如果按成绩查找请输3\n");
printf("请输入您查找的方式:");
scanf("%s",&choice);
if(choice=='1')
{
printf("请输入需要查找学生的学号:");
scanf("%d",&xx);
printf("您所查找的学生的信息为:\n");
printf("----学号----姓名----高数成绩----英语成绩----大学物理----\t\n");
for(i=0;i<shuliang;i++)
{
if(xx==student[i].number)
{
j=i;k=1;
printf("----%d-------%s-------%d-------%d-------%d----\t\n",student[j].number,student[j].name,student[j].gaoshu,student[j].yingyu,student[i].daxuewuli);
}
}
if(k==0)
printf("输入信息有误:\n");
}
else if(choice=='2')
{
printf("请输入需要查找学生的姓名:\n");
scanf("%s",yy);
printf("您所查找的学生的信息为:\n");
printf("----学号----姓名----高数成绩----英语成绩----大学物理----\t\n");
for(i=0;i<shuliang;i++)
{
if(strcmp(yy,student[i].name)==0)
{
j=i;k=1;
printf("----%d-------%s-------%d-------%d-------%d----\t\n",student[j].number,student[j].name,student[j].gaoshu,student[j].yingyu,student[j].daxuewuli);
}
}
if(k==0)
printf("输入信息有误:\n");
}
else if(choice=='3')
{
printf("请输入需要查找学生的成绩:\n");
scanf("%d",&xx);
printf("您所查找的学生的信息为:\n");
printf("----学号----姓名----高数----英语----计算机----\t\n");
for(i=0;i<shuliang;i++)
{
if(xx==student[i].grade)
{
j=i;k=1;
printf("----%d-------%s-------%d-------%d-------%d----\t\n",student[j].number,student[j].name,student[j].gaoshu,student[j].yingyu,student[i].daxuewuli);
}
}
if(k==0)
printf("输入信息有误:\n");
}
xiang();
}
void PaiXu()
{
struct student *p1[N],**p2,*temp;
int i,j,pjc;
system("CLS");
p2=p1;
for( i=0;i<shuliang;i++)
{
p1[i]=student+i;
}
for( i=0;i<shuliang;i++)
{
for( j=i+1;j<shuliang;j++)
{
if((*(p2+i))->sum<(*(p2+j))->sum)
{temp=*(p2+i);*(p2+i)=*(p2+j);*(p2+j)=temp;}
}
}
printf("按照总成绩排序之后的信息为:\n");
printf("----学号----姓名----总成绩----\t\n");
for( i=0;i<shuliang;i++)
{
student[i].sum=student[i].gaoshu+student[i].yingyu+student[i].daxuewuli;
pjc=(student[i].sum)/3;
printf("----%d-----%s----%d-----\n",(*(p2+i))->number,(*(p2+i))->name,(*(p2+i))->sum);
}
xiang();
}
void CunChu()
{
int i;
FILE *rs;
if((rs=fopen("student.txt","w"))==NULL)
{
printf("not open");
exit(0);
}
for(i=0;i<shuliang;i++)
{
fwrite(&student[i], sizeof(student[i]), 1, rs);
}
if(ferror(rs))
{
fclose(rs);
perror("写文件失败!\n");
return;
}
printf("存储文件成功!\n");
fclose(rs);
xiang();
}
void DaoChu()
{
struct student t;
int i=0;
FILE* fp = fopen("student.txt", "r");
shuliang=0;
if(NULL==fp)
{
perror("读取文件打开失败!\n");
return;
}
memset(student,0x0,sizeof(student));
while(1)
{
fread(&t,sizeof(t),1,fp);
if(ferror(fp))
{
fclose(fp);
perror("读文件过程失败!\n");
return;
}
if(feof(fp))
{
break;
}
student[i]=t;
i++;
}
fclose(fp);
shuliang=i;
printf("导出文件成功!\n");
xiang();
}
void menu()
{
int n=0;
system("CLS");
printf(" 学生信息管理系统\n");
printf(" 作者:孙召洋\n");
printf("-------------------MENU-----------------\n");
printf(" 1.登记学生信息\n");
printf(" 2.删除学生信息\n");
printf(" 3.浏览所有已经登记的学生\n");
printf(" 4.查找\n");
printf(" 4.1按学号查找\n");
printf(" 4.2按姓名查找\n");
printf(" 4.3按成绩查找\n");
printf(" 5.根据总成绩排序\n");
printf(" 5.1输出平均成绩\n");
printf(" 6.存储到文件\n");
printf(" 7.从文件导出\n");
printf(" 8.退出系统\n");
a: printf(" 请选择:");
scanf("%d",&n);
switch (n)
{
case 1:
DengJi();break;
case 2:
ShanChu();break;
case 3:
LiuLan();break;
case 4:
ChaZhao();break;
case 5:
PaiXu();break;
case 6:
CunChu();break;
case 7:
DaoChu();break;
case 8:
exit(0);break;
default:
{
printf("请输入1-8之间的数字,谢谢!\n");
goto a;
}
}
}
void main()
{
menu();
}
⑦ 学生成绩管理系统制作步骤,登录界面怎么做啊!我想自己先...
word里面的邮件合并功能,首先:视图——工具栏——邮件合并,点出邮件合并工具栏,然后在工具栏上点击“打开数据源”,把你那个excel文件导入进来,把光标定位在姓名栏——插入域——姓名——插入——关闭,其他各科成绩也是定位在相应的科目,然后重复上面的工作,不同的是插入域不是“姓名”,而是相应各科成绩(例如:物理,数学……)。全部插入完之后,查看合并数据,如果没有问题的话,就合并到新文档,把新文档打印出来就可以了。
⑧ 求怎么用C语言做一个学生成绩管理系统
去年写的,你稍微改下加个成绩就行
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
FILE *fp;
struct student{
char name[10];
char number[12];
char age[3];
struct student *next;
};
struct student *creat(); //手动创建链表
struct student *build_list(); //从文件读取信息创建链表
void read_list(struct student *head); //打印链表
void search(struct student *head); //查找相应信息
struct student *delete_(struct student *head); //删除相应信息
void ad_list(struct student *head); //增加信息
int control(struct student *head); //控制函数
void head_print(); //打印界面函数
void change_list(struct student *head); //更改链表信息函数
void save(struct student *head); //保存文件
void remove(struct student *head); //递归释放链表空间
char name[10],number[12],age[3]; //学生姓名、学号、年龄全局变量
int main(){
struct student *head;
head=(struct student*)malloc(sizeof(struct student));
control(head);
free(head);
fclose(fp);
return 0;
}
struct student *creat(){
struct student *head;
char name[10],number[12],age[3];
struct student *p,*r,*p1;
head=(struct student *)malloc(sizeof(struct student));
p=head->next;
r=head;
printf("依次输入姓名学号年龄(按q退出):\n");
scanf("%s",name);
while(name[0]!='q'){
p1=(struct student*)malloc(sizeof(struct student));
scanf("%s",number);
scanf("%s",age);
strcpy(p1->name,name);
strcpy(p1->number,number);
strcpy(p1->age,age);
p1->next=NULL;
r->next=p1;
r=p1;
scanf("%s",name);
}
printf("建立成功\n");
return head;
}
/*若无文件或文件为空,用链表创建函数,为防止占用多余内存在循环入口处进行判断,函数返回头指针地址*/
struct student *build_list(){
char ch;
struct student *head;
struct student *p1,*r;
rewind(fp);
head=(struct student*)malloc(sizeof(struct student));
r=head;
while(!feof(fp)){
p1=(struct student*)malloc(sizeof(struct student));
fscanf(fp,"%s%s%s",p1->name,p1->number,p1->age);
p1->next=NULL;
r->next=p1;
r=p1;
fseek(fp,2L,SEEK_CUR);
if((ch=getc(fp))==EOF)
break;
else
fseek(fp,-3L,SEEK_CUR);
}
return head;
}
/*文件内有信息时按行读取文件信息并创建链表,为防止误读结尾换行符,用fseek函数在每次循环后移两单位判断是否为空
,若为空结束循环,若不为空则用fseek函数前移三个单位*/
void read_list(struct student *head){
struct student *p;
p=head->next;
if(p==NULL){
head=creat();
}
printf("*******************************************\n");
while(p!=NULL){
printf("%-20s%-12s%-3s\n",p->name,p->number,p->age);
p=p->next;
}
printf("*******************************************\n");
}
/*输出链表信息,如果进行删除操作后链表为空则转到链表创建函数;按行读取文件信息并输出。*/
void search(struct student *head){
char s[20];
struct student *p;
int k=0;
printf("请输入要查询的字符串:\n");
p=head->next;
scanf("%s",s);
printf("查询结果:\n");
while(p!=NULL){
if((strcmp(s,p->age)&&strcmp(s,p->name)&&strcmp(s,p->number))==0){
printf("%-20s%-12s%-3s\n",p->name,p->number,p->age);
k=1;
}
p=p->next;
}
if(k==0)
printf("无记录\n");
}
/*查找函数,*/
struct student *delete_(struct student *head){
char s[20];
char ch;
int v=0;
struct student *p,*q;
printf("请输入要删除的学生的学号:\n");
scanf("%s",s);
p=head->next;
q=head;
while(p!=NULL){
if(strcmp(s,p->number)==0){
q->next=p->next;
v=1;
free(p);
break;
}
q=p;
p=p->next;
}
if(v==1)
printf("删除成功\n");
else{
printf("未删除成功\n");
return q->next;
}
if(head->next==NULL){
printf("已无信息,是否输入新的(Y/N):\n");
scanf("%c",&ch);
ch=getchar();
if(ch=='y')
head=creat();
return head;
}
return q->next;
}
void ad_list(struct student *head){
char s[20];
int v=0;
struct student *p,*q;
q=(struct student *)malloc(sizeof(struct student));
p=head->next;
printf("插在学号为多少的学生后?\n");
scanf("%s",s);
while(p!=NULL){
if(strcmp(s,p->number)==0){
printf("请输入学生信息(姓名 学号 年龄):\n");
scanf("%s%s%s",q->name,q->number,q->age);
q->next=p->next;
p->next=q;
v=1;
break;
}
p=p->next;
}
if(v==0)
printf("插入失败\n");
}
void change_list(struct student *head){
char s1[12];
char ch;
struct student *p;
printf("请输入要更改的学生的学号:\n");
scanf("%s",s1);
p=head->next;
while(p!=NULL){
if(strcmp(s1,p->number)==0)
break;
p=p->next;
}
printf("请输入要更改的内容:\na.姓名\nb.学号\nc.年龄\n");
scanf("%c",&ch);
ch=getchar();
printf("请输入更改后结果:\n");
scanf("%s",s1);
switch(ch){
case'a':strcpy(p->name,s1);break;
case'b':strcpy(p->number,s1);break;
case'c':strcpy(p->age,s1);break;
}
}
void save(struct student *head){
struct student *p;
p=head->next;
fp=fopen("stu.out","w+");
rewind(fp);
while(p!=NULL){
fprintf(fp,"%-20s%-12s%3s\n",p->name,p->number,p->age);
p=p->next;
}
printf("保存成功\n");
}
void remove(struct student *head){
if(head==NULL)
return;
remove(head->next);
free(head);
}
int control(struct student *head){
int i=0;
char ch;
head_print();
if((fp=fopen("stu.out","r"))==NULL){
printf("无文件,请先建立:\n");
head=creat();
}
else if((ch=getc(fp))==EOF){
printf("无信息,请先建立:\n");
head=creat();
}
else
head=build_list();
while((ch=getchar())!='q'){
switch(ch){
case'a':search(head);break;
case'b':delete_(head);break;
case'c':ad_list(head);break;
case'd':change_list(head);break;
case'e':read_list(head);break;
case'f':save(head);break;
case'h':head_print();
}
}
if(ch=='q')
remove(head);
return 0;
}
void head_print(){
printf("%13.0s********************************************%13.0s\n");
printf("%13.0s**%40.0s**\n");
printf("%13.0s**%9.0sa.查找%9.0sb.删除%10.0s**\n");
printf("%13.0s**%40.0s**\n");
printf("%13.0s**%9.0sc.增加%9.0sd.更改%10.0s**\n");
printf("%13.0s**%40.0s**\n");
printf("%13.0s**%9.0se.查看%9.0sf.存档%10.0s**\n");
printf("%13.0s**%40.0s**\n");
printf("%13.0s**%9.0s按h显示提示信息,q退出%10.0s**\n");
printf("%13.0s********************************************%13.0s\n");
}
⑨ 求!做一个学生成绩管理系统(c编程)
你好!
程序完成了吗?有个相似的程序,你看看吧,可以满足你的要求