iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C++实现教工考勤信息管理系统
  • 411
分享到

C++实现教工考勤信息管理系统

2024-04-02 19:04:59 411人浏览 薄情痞子
摘要

本文实例为大家分享了c++实现教工考勤信息管理系统的具体代码,供大家参考,具体内容如下 需求分析 传统意义上的考勤管理都是采用原始的手工操作来完成的。人事部的管理人员或办公室人员要进

本文实例为大家分享了c++实现教工考勤信息管理系统的具体代码,供大家参考,具体内容如下

需求分析

传统意义上的考勤管理都是采用原始的手工操作来完成的。人事部的管理人员或办公室人员要进行繁琐的记录、修改、查询、统计等工作,不仅时间长、劳动强度大、工作效率低下,并且容易出错。

1.1 问题提出

本人计划编写一个教工考勤信息管理系统,主要用来管理教工考勤信息。可以对信息进行排序,查询,输出,修改,添加,删除等操作。

1.2 本系统涉及的知识点

循环、分支、数组、函数、结构体、指针、文件

1.3 功能要求

(1) 排序:按教师号对所有教工的出勤信息进行排序。
(2) 查询:按特定条件查找教工的出勤信息。
(3) 更新:按编号对某个教工的某项出勤信息进行修改。
(4) 插入:加入新教工的出勤信息。
(5) 删除:按编号删除已离职的教工的出勤信息。
(6) 浏览:输出所有教工的出勤信息。

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#define 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 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--;//人数-1
    printf("删除成功!\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");
        }
    }
}

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

--结束END--

本文标题: C++实现教工考勤信息管理系统

本文链接: https://www.lsjlt.com/news/148928.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • C++实现教工考勤信息管理系统
    本文实例为大家分享了C++实现教工考勤信息管理系统的具体代码,供大家参考,具体内容如下 需求分析 传统意义上的考勤管理都是采用原始的手工操作来完成的。人事部的管理人员或办公室人员要进...
    99+
    2024-04-02
  • C++怎么实现教工考勤信息管理系统
    这篇“C++怎么实现教工考勤信息管理系统”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“C++怎么实现教工考勤信息管理系统”文...
    99+
    2023-06-30
  • C++实现考勤管理系统
    本文实例为大家分享了C++实现考勤管理系统的具体代码,供大家参考,具体内容如下 设计一考勤管理系统,记录学生的缺课情况 1、设计学生类;2、设计课程类;3、设计考勤类;4、录入学生的...
    99+
    2024-04-02
  • C++实现教职工信息管理系统
    本文实例为大家分享了C++实现教职工信息管理系统的具体代码,供大家参考,具体内容如下 一.问题描述 一个小公司包含四类人员:经理,技术人员,销售人员和销售经理,各类人员的工资计算方法...
    99+
    2024-04-02
  • C++如何实现考勤管理系统
    本篇内容主要讲解“C++如何实现考勤管理系统”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C++如何实现考勤管理系统”吧!设计一考勤管理系统,记录学生的缺课情况设计学生类;2、设计课程类;3、设...
    99+
    2023-06-29
  • C语言实现考勤管理系统
    这些天因为补修c语言课设,在花费了一段时间后写完了这个课设,课设的要求如下: 考勤信息记录了学生的缺课情况,它包括:缺课日期、第几节课、课程名称、学生姓名、缺课类型(迟到、早退、请假...
    99+
    2024-04-02
  • C++实现职工信息管理系统
    本文实例为大家分享了c++实现职工信息管理系统的具体代码,供大家参考,具体内容如下 1、项目需求 2、功能实现的具体思路为: (1) 经行职工信息的读入,用while循环进行读入,...
    99+
    2024-04-02
  • 考勤薪资管理系统的实现
    简介:本文将详细介绍如何使用Python和MySQL数据库开发一个基本的考勤薪资管理系统。该系统可以记录员工的工作时间和工资信息,并通过图形化界面显示数据,方便管理人员进行查询和分析。 正文: 一、系统需求分析在设计这个系统时,我们需要考虑...
    99+
    2024-01-25
    管理系统 薪资 考勤
  • 如何使用C++实现教职工信息管理系统
    这篇文章主要介绍如何使用C++实现教职工信息管理系统,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!具体内容如下一.问题描述一个小公司包含四类人员:经理,技术人员,销售人员和销售经理,各类人员的工资计算方法如下:经理:...
    99+
    2023-06-29
  • C++实现教职工信息管理系统课程设计
    本文实例为大家分享了C++实现教职工信息管理系统的具体代码,供大家参考,具体内容如下 #include<iostream> #include<cstring&g...
    99+
    2024-04-02
  • C++实现信息管理系统
    本文实例为大家分享了C++实现信息管理系统的具体代码,供大家参考,具体内容如下 有一个信息管理系统,要求检查每一个登录系统的用户(User)的用户名和口令,系统检查合格以后方可登录系...
    99+
    2024-04-02
  • 薪酬考勤管理系统
    薪酬考勤管理系统是一种用于管理和跟踪员工薪资和考勤记录的软件系统。它帮助企业实现工资计算、考勤记录、加班管理、请假审批等人力资源管理任务的自动化。本文将详细介绍薪酬考勤管理系统的主要功能以及如何选择适合企业的薪酬考勤管理系统的解决方案。1...
    99+
    2023-12-27
    管理系统 考勤 薪酬
  • 基于JavaWeb+MySQL的企业员工信息管理系统(考勤、工资、岗位、奖惩等)
    目录 绪论 1 1.1 设计背景 1 1.2 设计意义 1 1.3 设计思路 1需求分析 2 2.1 需求描述 2 2.2 用例建模 2 2.3 用例描述 3 2.3.1 个人信息用例描述 3 2.3...
    99+
    2023-10-27
    mysql java 员工信息管理系统 考勤系统 毕业设计
  • Python实现员工信息管理系统
    本文实例为大家分享了Python实现员工信息管理系统的具体代码,供大家参考,具体内容如下 1.职员信息管理系统 要求: 1、依次从键盘录入每位员工的信息,包括姓名、员工id、身份证号...
    99+
    2024-04-02
  • Java实现员工信息管理系统
    在Java SE中,对IO流与集合的操作在应用中比较重要。接下来,我以一个小型项目的形式,演示IO流、集合等知识点在实践中的运用。 该项目名称为“员工信息管理系统&rdq...
    99+
    2024-04-02
  • C语言实现学生考勤系统
    本文实例为大家分享了C语言实现学生考勤系统的具体代码,供大家参考,具体内容如下 项目要求: 学生考勤系统 功能:学生考勤系统应包含各班学生的全部信息。每个学生是一条记录,包括姓名、性...
    99+
    2024-04-02
  • C/C++实现图书信息管理系统
    本文实例为大家分享了c/c++实现图书信息管理系统的具体代码,供大家参考,具体内容如下 程序流程图 源代码 #include <stdio.h> #include ...
    99+
    2024-04-02
  • C语言实现简单职工信息管理系统
    本文实例为大家分享了C语言实现职工信息管理系统的具体代码,供大家参考,具体内容如下 代码实现如下: #include <stdio.h>//输入、输出指令 #includ...
    99+
    2024-04-02
  • C++实现图书信息管理系统
    本文实例为大家分享了C++实现图书信息管理系统的具体代码,供大家参考,具体内容如下 1.题目: 类型有:编号:ISBN书名:name价格:price 完成如下的功能: ①录入:从键盘...
    99+
    2024-04-02
  • 基于C++实现信息管理系统
    基于c++设计的信息管理系统,供大家参考,具体内容如下 1、使用类+函数实现2、使用STL容器的vector3、fstream的文件存储方式4、xls文件读入 写出5、数据的四大功能...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作