C语言实现职工管理系统

 更新时间:2019年11月27日 11:12:51   投稿:lijiao  
这篇文章主要为大家详细介绍了C语言实现职工管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

小编找到了一个特别好的职工管理系统,分享给大家一份C语言职工管理系统的具体实现代码,供大家参考,也谢谢这位网友的分享,具体内容如下

person.cpp

#include "person.h"

//首页
int Print_Head(int * num)
{
 printf("\t***********************************************\n");
 printf("\t|     职工管理系统    |\n");
 printf("\t*---------------------------------------------*\n");
 printf("\t|   【1】新增  【2】删改   |\n");
 printf("\t*   【3】查询  【4】退出   *\n");
 printf("\t***********************************************\n");
 printf("\t◎请输入想进行操作的序号【 】\b\b");
 *num=getchar();
 return SUCCESS;
}

//删改画面
int Print_DelRev(int* num)
{
 printf("\t******************************************\n");
 printf("\t*          *\n");
 printf("\t* 【1】删除 【2】修改 【3】返回 *\n");
 printf("\t*          *\n");
 printf("\t******************************************\n");
 printf("\t◎请输入想进行操作的序号【 】\b\b");
 *num=getchar();
 return SUCCESS;
}

//查询画面
int Print_Que(int* num)
{
 printf("\t******* ************************************\n");
 printf("\t*          *\n");
 printf("\t*  【1】全部查询 【2】工号查询  *\n");
 printf("\t*          *\n");
 printf("\t*  【3】模糊查询 【4】返回菜单  *\n");
 printf("\t*          *\n");
 printf("\t******************************************\n");
 printf("\t◎请输入想进行操作的序号【 】\b\b");
 *num=getchar();
 return SUCCESS;
}

//增加画面
int Print_Add(int* num)
{
 int n=0;
 printf("\t******************************************\n");
 printf("\t*          *\n");
 printf("\t* 【1】新增 【2】添加 【3】返回 *\n");
 printf("\t*          *\n");
 printf("\t******************************************\n");
 printf("\t◎请输入想进行操作的序号【 】\b\b");
 *num=getchar();
 return SUCCESS;
}

//标题头
int Print_Tittle()
{
 printf("-------------------------------------------\n");
 printf(" 工号 | 姓名 |性别|年龄| 电话  \n");
 printf("-------------------------------------------\n");
 return SUCCESS;
}

//选择将要打开的文件
int File_name()
{
 printf("\n\t◎请输入您想要打开的文件:");
 //memset(filename,0,sizeof(filename));
 if(scanf("%s", filename)!=1){
 printf("\a 选择文件错误!");
 return FAILED;
 }
 return SUCCESS;
}


//生成链表,参数n是add记录数量
struct Employee *Creat() {
 printf("\n\t◎请输入要添加的数据个数:");
 int n;
 if(scanf("%d", &n)!=1) {
 printf("\a error!");
 }
 struct Employee *head;
 struct Employee *p1, *p2;

 system("cls");
 for(int i=1;i<n+1;i++) {
 p1 = (struct Employee*)malloc(SIZE);
 Print_Tittle();
 scanf("%s%s%s%d%s",p1->num,p1->name,p1->sex,
 p1->age,p1->tel);
 p1->next = NULL;
 if(i==1) {
 head = p2 = p1;
 }
 else {
 p2->next = p1;
 p2 = p1;
 }
 }
 return(head);
}

//建立新文件
int WriteData_wb(struct Employee *head) {
 FILE *fp;
 struct Employee *p;
 if((fp = fopen(filename, "wb"))==NULL)
 printf("\a 打开文件错误!"); 
 p = head;
 while(p!=NULL) {
 if(fwrite(p,SIZE,1,fp)!=1) {
 printf("\b 写入数据出错\n");
 fclose(fp);
 return FAILED;
 }
 p=p->next;
 }
 fclose(fp);
 return SUCCESS;
}

//在已有文件添加
int WriteData_ab(struct Employee *head) {
 FILE *fp;
 struct Employee *p;
 if((fp = fopen(filename, "ab"))==NULL)
 printf("\a 打开文件错误!");
 p = head;
 while(p!=NULL) {
 if(fwrite(p,SIZE,1,fp)!=1) {
 printf("\b 写入数据出错\n");
 fclose(fp);
 return FAILED;
 }
 p=p->next;
 }
 fclose(fp);
 return SUCCESS;
}


//增加
int Emp_Add()
{
 system("cls");
 getchar();
 int add;
 while(1){
 system("cls");
 Print_Add(&add);
 while(add!='1' && add!='2' && add!='3') {
 putchar('\a');
 printf("◎请重新输入有效序号(1~3):【 】\b\b");
 add=getchar();
 }
 switch(add){
 case '1':
 WriteData_wb(Creat());
 printf("\n◎新建文件成功数据已保存√\n");
 system("pause");
 system("cls");
 Emp_Add();
 break;
 case '2':
 WriteData_ab(Creat());
 printf("\n◎数据已成功添加√\n");
 system("pause");
 system("cls");
 Emp_Add();
 break;
 case '3':
 system("cls");
 getchar();
 Emp_Return();
 break;
 }
 }
 return SUCCESS;
}

//读取文件的数据到链表中返回链表head指针
struct Employee *Read() {
 struct Employee *head = NULL;
 struct Employee *p1, *p2;//s = p1;p = p2;

 FILE *fp;
 if((fp=fopen(filename,"rb+"))==NULL)
 {
 printf("打开文件出错\n");
 exit(0);
 }
 while(!feof(fp)) {
 if((p1=(struct Employee*)malloc(SIZE))==NULL){
 printf("内存申请出错\n");
 fclose(fp);
 exit(0);
 }
 if(fread(p1,SIZE,1,fp)!=1){
 free(p1);
 break;
 }
 if(head==NULL)
 head=p2=p1;
 else{
 p2->next=p1;
 p2=p1;
 }
 }
 fclose(fp);
 return (head);
}

//删除
int Emp_Del()
{
 struct Employee* head;
 struct Employee* pt1,*pt2;
 char str_num[10];
 memset(str_num,0,sizeof(str_num));
 printf("\n◎请输入你要删除的学号信息:");
 scanf("%s",str_num);
 pt1=Read();
 pt2=pt1->next;
 head=pt1;
 while(pt2!=NULL){
 if(!strcmp(pt1->num,str_num)){
 WriteData_wb(pt2);
 }else if(!strcmp(pt2->num,str_num)){
 pt1->next=pt2->next;
 WriteData_wb(head);
 }
 pt2=pt2->next;
 pt1=pt1->next;
 }
 if(pt2!=NULL){
 printf("\t◎没有你要删除的数据");
 }
 return SUCCESS;
}

//修改
int Emp_Rev()
{
 struct Employee* pt1,*pt2,*head;
 char str_num[10];
 printf("\t◎请输入要修改的学号信息:");
 scanf("%s",str_num);
 pt1=Read();
 pt2=pt1->next;
 head=pt1;
 while(pt2!=NULL){
 if(strcmp(pt1->num,str_num)==0) {
 Print_Tittle();
 scanf("%s%s%s%d%s",pt1->num,pt1->name,pt1->sex,
 pt1->age,pt1->tel);
 WriteData_wb(head);
 }
 else if(strcmp(pt2->num,str_num)==0) {
 Print_Tittle();
 scanf("%s%s%s%d%s",pt1->num,pt1->name,pt1->sex,
 pt1->age,pt1->tel);
 WriteData_wb(head);
 }
 pt2 = pt2->next;
 pt1 = pt1->next;
 }
 if(pt2!=NULL)
 printf("数据库中没有存储您要删除的数据!\n");
 return 0;
}

//删改
int Emp_DelRev()
{
 
 getchar();
 int delrev=0;
 while(1){
 system("cls");
 Print_DelRev(&delrev);
 while(delrev!='1' && delrev!='2' && delrev!='3'){
 putchar('\a');
 //getchar();
 printf("○请重新输入有效序号(1~3):【 】\b\b");
 delrev=getchar();
 }
 switch(delrev){
 case '1':
 Emp_Del();
 printf("\n◎已成功删除指定数据!");
 system("pause");
 getchar();
 break;
 case '2':
 Emp_Rev();
 printf("\n◎已成功修改指定数据!");
 system("pause");
 getchar();
 break;
 case '3':
 system("cls");
 getchar();
 Emp_Return();
 break;
 }
 }
 return SUCCESS;
}

//总体查询
int Emp_QueAll()
{
 struct Employee *pt;
 pt = Read();
 Print_Tittle();
 do {
 printf("%2s%5s%4s%2d%3s\n",
 pt->num,pt->name,pt->sex,pt->age,pt->tel);
 pt = pt->next;
 }while(pt!=NULL);
 printf("\n\n");
 return SUCCESS;
}

//工号查询
int Emp_QueNum() 
{
 struct Employee *pt;
 char str_num[10];
 printf("\t◎请输入您要查询的学号:");
 scanf("%s", str_num);
 pt = Read();
 Print_Tittle();
 do {
 if(!strcmp(pt->num,str_num)) {
 printf("%2s%5s%4s%2d%3s\n",
 pt->num,pt->name,pt->sex,pt->age,pt->tel);
 printf("\n\n");
 return 0;
 }
 pt = pt->next;
 }while(pt!=NULL);
 printf("\t数据库中没有存储您要查询的数据!\n");
 printf("\n\n");
 return SUCCESS;
}

//模糊查询
int Emp_QueVague()
{
 struct Employee *pt;
 char str_vague[20];
 int m=0;
 printf("\t◎请输入您要查询的关键词:");
 scanf("%s", str_vague);
 pt = Read();
 Print_Tittle();
 do {
 if(strstr(pt->num,str_vague)!=0||strstr(pt->name,str_vague)!=0
 ||strstr(pt->sex,str_vague)!=0||strstr(pt->age,str_vague)!=0
 ||strstr(pt->tel,str_vague)!=0) {
 printf("%2s%5s%4s%2d%3s\n",
 pt->num,pt->name,pt->sex,pt->age,pt->tel);
 m = 1;
 }
 pt = pt->next;
 }while(pt!=NULL);
 if(!m)
 printf("数据库中没有存储您要查询的数据!\n");
 printf("\n\n");
 return SUCCESS;
}

//查询
int Emp_Que()
{
 system("cls");
 int que;
 while(1){
 system("cls");
 Print_Que(&que);
 while(que!='1' && que!='2' && que!='3'){
 putchar('\a');
 printf("\t○请重新输入有效序号(1~3):【 】\b\b");
 que=getchar();
 }
 switch(que){
 case '1':
 Emp_QueAll();
 system("pause");
 getchar();
 break;
 case '2':
 Emp_QueNum();
 system("pause");
 getchar();
 break;
 case '3':
 Emp_QueVague();
 system("pause");
 getchar();
 break;
 case '4':
 Emp_Return();
 system("pause");
 getchar();
 break;
 }
 }
 return SUCCESS;
}

//返回
int Emp_Return()
{
 Emp_Menu();
 return SUCCESS;
}

//退出
void Emp_Quit()
{
 printf("\n\t◎谢谢使用!");
 system("pause");
 exit(0);
}

//menu函数
int Emp_Menu()
{
 //int* Menu=NULL;
 int menu=0;
 //Print_Head(&Menu);
 //menu=*Menu;
 //delete Menu;
 //printf("%d\n",menu);
 Print_Head(&menu);
 
 while(menu!='1' && menu!='2' && menu!='3'&& menu!='4') {
 printf("error! please input the right number!\n");
 putchar('\a');
 //getchar();
 printf("◎请重新输入有效序号(1~4):【 】\b\b");
 menu=getchar();
 }
 switch(menu){
 case '1': 
 File_name();
 Emp_Add();
 break;
 case '2': 
 File_name();
 Emp_DelRev();
 break;
 case '3': 
 File_name();
 Emp_Que();
 break;
 case '4': 
 Emp_Quit();
 break;
 }
 return SUCCESS;
}
/*void Sig(int n)
{
 printf("\n\t◎程序将要退出,操作已保存!");
 system("pause");
 exit(0);
}*/
int main()
{
 //printf("\t◎使用Ctrl+C终止现在程序的运行!\n");
 //signal(SIGINT,Sig);
 Emp_Menu();
 return SUCCESS;
}

person.h

#ifndef __PERSON_H__
#define __PERSON_H_
#define _CRT_SECURE_NO_DEPRECATE
#define _CRT_SECURE_CPP_OVERLOAD_STANDARD_NAMES 1
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <conio.h>
#include <signal.h>
#define SUCCESS  0
#define FAILED (!SUCCESS)
#define SIZE sizeof(struct Employee)
//全局变量
int flag=0;//返回标志
char filename[30];//要打开的文件名
//员工信息结构体
struct Employee{
 char name[20];
 char tel[15];
 char sex[5]; 
 char num[10];
 char age[3];
 struct Employee* next;
};

//建立一个链表
struct Employee* creat(int n);

//主函数
int Emp_Menu();
//首页打印
int Print_Head();
//删改打印
int Print_DelRev();
//增加打印
int Print_Add();
//表头打印
int Print_Tittle();
//新建文件写入
int WriteData_wb(struct Employee *head);
//在已有的文件写入
int WriteData_ab(struct Employee *head);
//添加
int Emp_Add();
//删除
int Emp_Del();
//修改
int Emp_Rev();
//查询
int Emp_Que();
//返回
int Emp_Return();
//退出
void Emp_Quit();

#endif //__PERSON_H__

更多学习资料请关注专题《管理系统开发》。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • cin.get()和cin.getline()之间的区别

    cin.get()和cin.getline()之间的区别

    以下是对cin.get()和cin.getline()的区别进行了详细的分析介绍,需要的朋友可以过来参考下,希望对大家有所帮助
    2013-09-09
  • C++封装IATHOOK类实例

    C++封装IATHOOK类实例

    这篇文章主要介绍了C++封装IATHOOK类的实现方法,对IAT的HOOK实例进行了封装,非常具有实用价值,需要的朋友可以参考下
    2014-10-10
  • 算法之排序算法的算法思想和使用场景总结

    算法之排序算法的算法思想和使用场景总结

    这篇文章主要介绍了算法之排序算法的算法思想和使用场景总结,本文讲解了插入排序、交换排序、选择排序等几大类排序算法的特点、思想和使用场景,需要的朋友可以参考下
    2014-08-08
  • C++实现LeetCode(149.共线点个数)

    C++实现LeetCode(149.共线点个数)

    这篇文章主要介绍了C++实现LeetCode(149.共线点个数),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-07-07
  • C++递归实现螺旋数组的实例代码

    C++递归实现螺旋数组的实例代码

    这篇文章主要介绍了C++递归实现螺旋数组的实例代码,代码简单易懂,非常不错,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-04-04
  • C++异常处理 try,catch,throw,finally的用法

    C++异常处理 try,catch,throw,finally的用法

    这篇文章主要介绍了C++异常处理 try,catch,throw,finally的用法,需要的朋友可以参考下
    2018-01-01
  • C++中关于set删除的一些坑

    C++中关于set删除的一些坑

    这篇文章主要介绍了C++中关于set删除的一些坑,因为这个问题浪费了很多的时间,所以想着分享出来给大家,方便同样遇到这个问题的朋友们,有需要的朋友们下面来一起看看吧。
    2017-02-02
  • C++实现LeetCode(22.生成括号)

    C++实现LeetCode(22.生成括号)

    这篇文章主要介绍了C++实现LeetCode(22.生成括号),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-07-07
  • 详解c++ atomic原子编程中的Memory Order

    详解c++ atomic原子编程中的Memory Order

    在多核编程中,我们使用内核对象【如:事件对象(Event)、互斥量对象(Mutex,或互斥体对象)、信号量对象(Semaphore)等】来避免多个线程修改同一个数据时产生的竞争条件。本文将详细介绍c++ atomic原子编程中的Memory Order。
    2021-06-06
  • 深入探讨:main函数执行完毕后,是否可能会再执行一段代码?

    深入探讨:main函数执行完毕后,是否可能会再执行一段代码?

    本篇文章是对main函数执行完毕后,是否可能会再执行一段代码,进行了详细的分析介绍,需要的朋友参考下
    2013-05-05

最新评论