本文主要是介绍教工考勤信息管理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
一、实践目的与要求
1、目的
通过此次实践环节主要达到以下目的:
(1)进一步理解和运用结构化程序设计的思想和方法,学会根据具体问题选择合理的计算机存储结构实现数据的存储,构造较有效率的算法;
(2)学会算法描述的方法,并编制具有结构清晰、合理和易读性的小型实用程序;
(3)并会设计测试方案,完成程序的测试,能撰写出该程序的技术报告,为文档整理工作打下一个初步的基础;
(4)培养小组成员间互相学习,取长补短,协同工作的能力。
2、要求
(1)模块化程序设计,锯齿型书写格式,代码要有足够的注释;
(2)根据课题中规定的要求实现既定目标;
(3)撰写格式排版规范、结构完整的技术文档。
二、课题任务
(题目、内容及主要功能描述)
题目:教工考勤信息管理
内容:系统能够完成出勤信息的查询、更新、插入、删除、排序等功能。
(1) 排序:按教师号对所有教工的出勤信息进行排序。
(2) 查询:按特定条件查找教工的出勤信息。
(3) 更新:按编号对某个教工的某项出勤信息进行修改。
(4) 插入:加入新教工的出勤信息。
(5) 删除:按编号删除已离职的教工的出勤信息。
(6) 浏览:输出所有教工的出勤信息。
#include <stdio.h>
#include <stdlib.h>
#include <string.h>const int LIST_MAX_SIZE = 100;//顺序表最大长度typedef struct //定义的用于表示学生信息
{char num[8];//教师号char name[20];//姓名char sex[10];//性别char study[20];//学历char date[20];//日期char phone[20];//电话char location[20];//职称char chuqin[20];//出勤情况char remarks [30];//备注
}Teacher;typedef struct
{Teacher data[LIST_MAX_SIZE];//数据域int length;//表长
}SqList;//功能设计
void add(SqList *L1);//添加教工考勤信息
void ran(SqList *L1);//出勤信息排序
void select_num(SqList *L1);//按教工查询
void select_name(SqList *L1);//按教工名查询
void select_all(SqList *L1);//查询所有教工
void delete_teacher(SqList *L1);//删除教工考勤信息
void change(SqList *L1);//改变教工考勤信息
void read(SqList *L1);//文件读教工考勤信息
void write(SqList *L1);//文件写教工考勤信息
void add(SqList *L1);//添加新考勤信息
void menu();//菜单void menu()//菜单
{system("cls");//清屏printf("1、教师信息录入\n");printf("2、教师信息浏览\n");printf("3、按教师号查询\n");printf("4、按照姓名查询\n");printf("5、修改教师信息\n");printf("6、删除教师信息\n");printf("7、按教师号排序\n");printf("0、退出\n");
}int main()
{char x;SqList *L1;L1 = (SqList*)malloc(sizeof(SqList));L1->length = 0;read(L1);//文件读while (1){menu();//界面登陆printf("请输入你的选择:");scanf("%c", &x);switch (x){case '1':add(L1);//教师信息录入write(L1);//文件写入毕业生信息break;case '2':select_all(L1);//毕业生信息浏览break;case '3':select_num(L1);//按照学号查询break;case '4':select_name(L1);//按照姓名查询break;case '5':change(L1);//修改毕业生信息write(L1);//文件写入毕业生信息break;case '6':delete_teacher(L1);//删除毕业生信息write(L1);//文件写入毕业生信息break;case '7':ran(L1);//按照学号进行排序break;case '0':return 0;default:printf("输入有误,请重新选择!\n");break;}getchar();system("pause");}return 0;
}
void delete_teacher(SqList *L1)//删除教师
{int i,j;char no[20];printf("输入教师号:");scanf("%s",no);for(i=0;i<L1->length;i++)//遍历输出{if(!strcmp(no,L1->data[i].num))//如果学号一样{break;}}if(i==L1->length)//查询到表尾都没有跳出循环{printf("删除失败!\n");return;}for(j=i;j<L1->length-1;j++){L1->data[j]=L1->data[j+1];//用后一个覆盖前面一个 达到删除的效果}L1->length--;//人数-1printf("删除成功!\n");
}void change(SqList *L1)//改变毕业生信息
{int i;char no[20];printf("输入教师号:");scanf("%s",no);for(i=0;i<L1->length;i++)//遍历输出{if(!strcmp(no,L1->data[i].num))//如果学号一样{break;}}if(i==L1->length)//查询到表尾都没有跳出循环{printf("修改失败!\n");return;}printf("请输入姓名:");scanf("%s",L1->data[i].name);printf("请输入性别:");scanf("%s",L1->data[i].sex);printf("请输入学历:");scanf("%s",L1->data[i].study);printf("请输入电话:");scanf("%s",L1->data[i].phone);printf("请输入职称:");scanf("%s",L1->data[i].location);printf("请输入考勤日期(xxxx-xx-xx):");scanf("%s",L1->data[i].date);printf("请输入出勤情况:");scanf("%s",L1->data[i].chuqin);printf("请输入备注:");scanf("%s",L1->data[i].remarks);printf("修改成功!\n");
}void ran(SqList *L1)//按教师号排序
{int i,j;Teacher temp;for(i=0;i<L1->length;i++){for(j=i+1;j<L1->length;j++)//选择排序 每次循环排好一个data[i]{if(strcmp(L1->data[i].num,L1->data[j].num)>0)//如果需要交换 {temp=L1->data[i];L1->data[i]=L1->data[j];L1->data[j]=temp;}}}printf("输出根据教师号排序后的结果:\n");select_all(L1);//排序完显示
}
void select_num(SqList *L1)//按号查询
{int i,flag=0;char no[20];printf("输入教师号:");scanf("%s",no);for(i=0;i<L1->length;i++)//遍历查找{if(!strcmp(no,L1->data[i].num))//如果和输入的教师号一样{flag=1;printf("%-10s%-10s%-10s%-10s%-20s%-10s%-20s%-20s%-20s\n","教师号","姓名","性别","学历","电话","职称","考勤日期","出勤情况","备注");printf("%-10s%-10s%-10s",L1->data[i].num,L1->data[i].name,L1->data[i].sex);printf("%-10s%-20s%-10s",L1->data[i].study,L1->data[i].phone,L1->data[i].location);printf("%-20s%-20s%-20s\n",L1->data[i].date,L1->data[i].chuqin,L1->data[i].remarks); }}if(flag==0)//查询到表尾都没有跳出循环{printf("无该教师信息!\n");}
}void select_name(SqList *L1)//按姓名查询
{int i,flag=0;char name[20];printf("输入教师姓名:");scanf("%s",name);for(i=0;i<L1->length;i++)//遍历查找{if(!strcmp(name,L1->data[i].name))//如果姓名一样 {printf("%-10s%-10s%-10s%-10s%-20s%-10s%-20s%-20s%-20s\n","教师号","姓名","性别","学历","电话","职称","考勤日期","出勤情况","备注");printf("%-10s%-10s%-10s",L1->data[i].num,L1->data[i].name,L1->data[i].sex);printf("%-10s%-20s%-10s",L1->data[i].study,L1->data[i].phone,L1->data[i].location);printf("%-20s%-20s%-20s\n",L1->data[i].date,L1->data[i].chuqin,L1->data[i].remarks); flag=1;//设置标志 表示查询到了 这里不跳出 是因为 姓名可能会重复 需要把重复的人也显示}}if(flag==0)//查询到表尾都没有跳出循环{printf("无该姓名信息!\n");}}void add(SqList *L1)
{if(L1->length>=LIST_MAX_SIZE)//如果达到了最大长度{printf("顺序表满,无法添加!\n");return ;}printf("请输入教师号:");scanf("%s",L1->data[L1->length].num);//信息存入表尾 L1->length 是顺序表当前长度 第L1->length个元素并未被使用 所以直接存在里面printf("请输入姓名:");scanf("%s",L1->data[L1->length].name);printf("请输入性别:");scanf("%s",L1->data[L1->length].sex);printf("请输入学历:");scanf("%s",L1->data[L1->length].study);printf("请输入电话:");scanf("%s",L1->data[L1->length].phone);printf("请输入职称:");scanf("%s",L1->data[L1->length].location);printf("请输入考勤日期(xxxx-xx-xx):");scanf("%s",L1->data[L1->length].date);printf("请输入出勤情况:");scanf("%s",L1->data[L1->length].chuqin);printf("请输入备注:");scanf("%s",L1->data[L1->length].remarks);L1->length++;//表长+1 使得刚刚存的数据有效
}void select_all(SqList *L1)//显示所有的教师信息
{int i;if(L1->length==0)//顺序表长度为0{printf("无教师信息!\n");return;}printf("%-10s%-10s%-10s%-10s%-20s%-10s%-20s%-20s%-20s\n","教师号","姓名","性别","学历","电话","职称","考勤日期","出勤情况","备注");for(i=0;i<L1->length;i++)//遍历输出{printf("%-10s%-10s%-10s",L1->data[i].num,L1->data[i].name,L1->data[i].sex);printf("%-10s%-20s%-10s",L1->data[i].study,L1->data[i].phone,L1->data[i].location);printf("%-20s%-20s%-20s\n",L1->data[i].date,L1->data[i].chuqin,L1->data[i].remarks);}
}void read(SqList *L1)//文件读
{FILE *fp;int a = 0;//a,用来识别到底有没有删除数据.t,用来接收fsacnf函数的返回值(为-1是说明无数据)if ((fp = fopen("teacher.txt", "r+")) == NULL)//‘r’允许读{printf("文件打开失败!\n");return;}else{while (!feof(fp)){a = 1;fread(&L1->data[L1->length++],sizeof(Teacher),1,fp);}fclose(fp); //关闭文件if (a == 0){printf("文本无数据,教工考勤信息读取失败\n");}else{L1->length--;}}
}void write(SqList *L1)//文件写
{FILE *fp;int t = 0;int i;if ((fp = fopen("teacher.txt", "w+")) == NULL){printf("文件打开失败!\n");return;}else{for (i = 0; i < L1->length; i++){t=1;fwrite(&L1->data[i],sizeof(Teacher),1,fp);}fclose(fp); //关闭文件if(L1->length==0){t=1;}if (t == 1){printf("教师信息写入完成\n");}else{printf("教工考勤信息写入失败\n");}}
}
这篇关于教工考勤信息管理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!