基于文件的学生管理系统(c语言实现)

主要是文件的打开和读写方式,较为简单。

基于文件的学生管理系统 •要求:

 

  1)、定义学生结构体,包含学号、姓名、成绩三个属性。

 

  2)、实现功能如下:

 

  添加学生

 

  根据学号删除学生

 

  根据学号修改学生信息

 

  根据学号查询单个学生的信息

 

  显示所有学生的信息

 

  按照成绩从高到低进行重新排序

 

  退出系统

#include <stdio.h>
#include <stdlib.h>
struct Student
{
    int id;
    char name[20];
    float s;
}std[1000];
void tianjia() //添加新的学生
{
    FILE *fd;

    fd = fopen("1.txt","a+");
    printf("请输入学生学号:\n");
    scanf("%d",&std[0].id);
    printf("请输入学生姓名:\n");
    scanf("%s",std[0].name);
    printf("请输入学生成绩:\n");
    scanf("%f",&std[0].s);
    fwrite(&std[0],sizeof(struct Student),1,fd);
    fclose(fd);
    printf("添加成功!\n");

}
void xianshi()  //显示所有的学生数据
{
    FILE *fd;
    int i ;
    fd = fopen("1.txt","r");
    for(i = 0; fread(&std[i],sizeof(struct Student),1,fd) == 1;i++)
    {
        printf("学号:%d\n",std[i].id);
        printf("姓名:%s\n",std[i].name);
        printf("成绩:%g\n",std[i].s);
        printf("*******************************\n");
    }
    fclose(fd);


}
void shanchu() //删除(以学号)
{
    FILE *fd;
    int id;
    int a;
    int i,j;
    fd = fopen("1.txt","r");
    printf("请输入要删除学生的学号:\n");
    scanf("%d",&id);
    for(i =0;fread(&std[i],sizeof(struct Student),1,fd) == 1;i++)
    {
        if(std[i].id == id)
            {

                printf("删除成功!\n");
                printf("删除的学生为:%s\n",std[i].name);
                a = i;

            }


    }
    fclose(fd);


    fd = fopen("1.txt","w");
    for(j=0;j<i;j++)
    {
         if(j!=a)
         fwrite(&std[j],sizeof(struct Student),1,fd);
    }
    fclose(fd);

}
void xiugai() //修改学生数据
{
    FILE *fd;
    int id;
    int n=-1;
    int i,j;
    fd = fopen("1.txt","r");
    printf("请输入要修改学生的学号:\n");
    scanf("%d",&id);
   for( i = 0;fread(&std[i],sizeof(struct Student),1,fd) == 1;i++)
    {
       if(std[i].id == id)
       {
            printf("要修改的学生资料如下:\n");
            printf("学号:%d\n",std[i].id);
            printf("姓名:%s\n",std[i].name);
            printf("成绩:%g\n",std[i].s);
            n = i;


       }
   }
    if(n==-1)
    {
        printf("改学生不存在,请重新选择功能!\n");
        return;
    }
   fclose(fd);


    printf("请输入新的学号:\n");
    scanf("%d",&std[n].id);
    printf("请输入新的姓名:\n");
    scanf("%s",std[n].name);
    printf("请输入新的成绩:\n");
    scanf("%f",&std[n].s);
    fd = fopen("1.txt","w");
    for(j=0;j<i;j++)
         fwrite(&std[j],sizeof(struct Student),1,fd);

    fclose(fd);


    printf("修改后改的资料为:\n");
    printf("学号:%d\n",std[n].id);
    printf("姓名:%s\n",std[n].name);
    printf("成绩:%g\n",std[n].s);

}
void chaxun() //查询数据(以学号)
{
    FILE*fd;
    int id;
    fd = fopen("1.txt","r");
    printf("请输入要查询学生的学号:\n");
    scanf("%d",&id);
    for(int i =0;fread(&std[i],sizeof(struct Student),1,fd) ==1;i++)
    {
        if(std[i].id == id)
        {
            printf("学号为%d的学生资料为:\n",id);
            printf("学号:%d\n",std[i].id);
            printf("姓名:%s\n",std[i].name);
            printf("成绩:%g\n",std[i].s);
        }
    }
    fclose(fd);
}
void paixu()//排序从高到低,运用了选择排序
{
    FILE *fd;
    int i,j,k;
    struct Student t;
    fd = fopen("1.txt","r");
    for(i = 0;fread(&std[i],sizeof(struct Student),1,fd) ==1;i++);

         for(j=0;j<i-1;j++)
        for(k=j+1;k<i;k++)
    {
        if(std[j].s<std[k].s)
        {
            t = std[j];
            std[j] = std[k];
            std[k] = t;
        }
    }
    fclose(fd);
    fd = fopen("1.txt","w");
    for(j=0;j<i;j++)
        fwrite(&std[j],sizeof(struct Student),1,fd);
    fclose(fd);
    printf("排序成功!\n");

}
int main()
{
    int n;
    printf("*******************************\n欢迎进入学生管理系统!\n");
    printf("*******************************\n");
    while(1)
    {

        printf("请输入选项进入功能:\n");
        printf("1.添加学生\n");
        printf("2.删除学生\n");
        printf("3.修改学生信息\n");
        printf("4.查询学生信息\n");
        printf("5.显示所有学生信息\n");
        printf("6.排序(按照成绩由高到低)\n");
        printf("7.退出系统\n");
        printf("*******************************\n");
        scanf("%d",&n);
        switch(n)
        {
        case 1:
         tianjia();
            break;
        case 2:
            shanchu();
            break;
        case 3:
            xiugai();
            break;
        case 4:
            chaxun();
            break;
        case 5:
            xianshi();
            break;
        case 6:
            paixu();
            break;
        case 7:
           exit(-1);
            break;
        default:
            printf("输入错误!\n");
        }
        printf("*******************************\n\n\n");
    }
    return 0;
}
 

C语言学生成绩管理系(以包含文件的形式写的),结构体,链表,数组,以下是main.c #include #include #include #define m 3/*宏定义m的值为3*/ struct node/*链表初始化*/ { char name[20]; int no; float score[m]; float sum; float avg; struct node *next; }; char ch[m+4][20]={{"学号"},{"姓名"},{"语文"},{"数学"},{"英语"},{"总分"},{"平均分"}};/*定义并初始化一个全局二维字符数组*/ #include "save.c"/*包含保存文件*/ #include "read.c"/*包含读取文件*/ #include "output.c"/*包含打印文件*/ #include "set.c"/*包含录入文件*/ #include "demand.c"/*包含查询文件*/ #include "sort.c"/*包含排序文件*/ #include "modified.c"/*包含修改文件*/ #include "add.c"/*包含添加文件*/ #include "del.c"/*包含删除文件*/ void main() { int n; printf("\n\t\t\t欢迎使用学生成绩管理系\n\n"); printf("\t\t\t\t\t\t制 作: XIA XIA\n"); do { printf("\n\n1:学生成绩录入,并保存\n"); printf("2:学生成绩查询\n"); printf("3:学生成绩的排序\n"); printf("4:学生成绩的修改\n"); printf("5:学生成绩的打印\n"); printf("6:学生信息的添加\n"); printf("7:学生信息的删除\n"); printf("0:退出学生成绩管理系\n\n\n"); printf("输入你要执行操作的相应序号\n"); scanf("%d",&n);/*输入相就的操作的序号*/ switch (n) { case 1: set();break;/*调用录入函数*/ case 2: demand();break;/*调用查询函数*/ case 3: sort();break;/*调用排序函数*/ case 4: modified();break;/*调用修改函数*/ case 5: output();break;/*调用打印函数*/ case 6: add();break;/*调用添加函数*/ case 7: del();break;/*调用删除函数*/ case 0: printf("正在退出学生成绩管理系......\n");exit(0);/*直到输入“0”退出学生成绩管理系*/ default:printf("输入错误码,请重新输入\n"); } }while(1); }
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值