C语言通讯录管理系统完整代码

 更新时间:2022年08月03日 14:55:22   作者:weixin_45859003  
这篇文章主要为大家详细介绍了C语言通讯录管理系统完整代码,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了C语言实现通讯录管理系统的具体代码,供大家参考,具体内容如下

设计内容:

设计一个通讯录管理系统,以实现以下功能:信息添加、查询、修改、删除、排序等功能。

设计要求:

1) 每条信息至包含 :姓名、电话、工作单位等信息
2) 作为一个完整的系统,应具有友好的界面和较强的容错能力

预览:

代码:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <windows.h> 
#define LEN sizeof(struct list)
#define DATA a[i].num,a[i].name,a[i].job,a[i].address
#define FORMAT "\t\t  ||    %-12d %-12s %-19s %-20s ||\n"
void in();
void menu();
void search();
void del();
void show();
void modify();
void insert();
void order();
void total();
struct list
{
    int num;        //号码
    char name[15];    //姓名
    char job[30];    //工作单位
    char address[30];    //地址            
};
struct list a[50];

void main()
{
    system("color 5e\n");
    menu();
    int n;
    scanf("%d", &n);
    while (n)
    {
        switch (n)
        {
        case 1:in();         break;
        case 2:search();     break;
        case 3:del();        break;
        case 4:modify();    break;
        case 5:insert();    break;
        case 6:order();        break;
        case 7:total();        break;
        case 8:show();        break;
        default:break;
        }
        getch();
        menu();//执行完后显示菜单 
        scanf("%d", &n);
    }

}

void menu()    
{
    system("cls");
    printf("\n\n\n");
    printf("\t\t\t\t\t**************************************\n");
    printf("\t\t\t\t\t************通讯录管理系统************\n");
    printf("\t\t\t\t\t======================================\n");
    printf("\t\t\t\t\t*          1.录入联系人信息          *\n");
    printf("\t\t\t\t\t*          2.查找联系人信息          *\n");
    printf("\t\t\t\t\t*          3.删除联系人信息          *\n");
    printf("\t\t\t\t\t*          4.修改联系人信息          *\n");
    printf("\t\t\t\t\t*          5.插入联系人信息          *\n");
    printf("\t\t\t\t\t*          6.排序                    *\n");
    printf("\t\t\t\t\t*          7.统计联系人总数          *\n");
    printf("\t\t\t\t\t*          8.显示所有联系人          *\n");
    printf("\t\t\t\t\t*          0.退出系统                *\n");
    printf("\t\t\t\t\t======================================\n");
    printf("\t\t\t\t\t**************************************\n");
    printf("\t\t\t\t\t          请选择(0-8):");
}

void in()
{
    int i, m = 0;
    char ch[2];
    FILE* fp;
    if ((fp = fopen("data.txt", "a+")) == NULL)
    {
        printf("\t\t  文件不存在! \n");
        return;
    }
    while (!feof(fp))
    {
        if (fread(&a[m], LEN, 1, fp) == 1)
            m++;
    }
    fclose(fp);
    if (m == 0)
    {
        printf("\t\t  文件中没有记录!\n");

    }
    else
    {
        show();
    }
    if ((fp = fopen("data.txt", "a+")) == NULL)
    {
        printf("\t\t  文件不存在!\n");
        return;
    }
    printf("\t\t  是否输入联系人信息(y/n):");
    scanf("%s", ch);
    while (strcmp(ch, "Y") == 0 || strcmp(ch, "y") == 0)
    {
        printf("\t\t  电话:");
        scanf("%d", &a[m].num);
        for (i = 0; i < m; i++)
        {
            if (a[i].num == a[m].num)
            {
                printf("\t\t  此用户已经存在了,按任意键继续!");
                getch();
                fclose(fp);
                return;
            }
        }

        printf("\t\t  姓名:");
        scanf("%s", &a[m].name);
        printf("\t\t  工作单位:");
        scanf("%s", &a[m].job);
        printf("\t\t  地址:");
        scanf("%s", &a[m].address);
        if (fwrite(&a[m], LEN, 1, fp) != 1)
        {
            printf("\t\t  不能保存");
            getch();
        }
        else
        {
            printf("\t\t  %s 已被保存!\n", a[m].name);
            m++;
        }
        printf("\t\t  继续?(y/n):");
        scanf("%s", ch);
    }
    fclose(fp);
    printf("\t\t  结束录入!\n");
}
void del()
{
    show();
    FILE* fp;
    int nmb, i, j, m = 0;
    int t = 1;        //判断是否正常结束 
    char ch[2];
    if ((fp = fopen("data.txt", "r+")) == NULL)
    {
        printf("\t\t  \n文件不存在\n");
        return;
    }
    while (!feof(fp))
    {
        if (fread(&a[m], LEN, 1, fp) == 1)
            m++;
    }
    fclose(fp);
    if (m == 0)
    {
        printf("\t\t  \n文件没有记录!\n");
        return;
    }
    printf("\t\t  输入要删除的联系人的电话号码:");
    scanf("%d", &nmb);
    for (i = 0; i < m; i++)
        if (nmb == a[i].num)
        {
            printf("\t\t  找到这条记录是否删除(y/n):");
            scanf("%s", &ch);
            if (strcmp(ch, "Y") == 0 || strcmp(ch, "y") == 0)
            {
                for (j = i + 1; j < m; j++)
                    a[j - 1] = a[j];
                m--;
                if ((fp = fopen("data.txt", "w+")) == NULL)
                {
                    printf("\t\t  文件不存在\n");
                    return;
                }
                for (j = 0; j < m; j++)
                {
                    if (fwrite(&a[j], LEN, 1, fp) != 1)
                    {
                        printf("\t\t  无法写入文件!删除失败!");
                        getch();
                    }
                }
                fclose(fp);
                printf("\t\t  删除成功");
            }
            else
            {
                fclose(fp);
                printf("\t\t  找到了记录选择不删除");
            }
            t = 0;    //标志找到该联系人 
            break;
        }
    if (t)
        printf("\t\t  没有找到该联系人!\n");
}

void modify()
{
    show();
    FILE* fp;
    int i = 0, j = 0, m = 0, nmb;
    if ((fp = fopen("data.txt", "r+")) == NULL)
    {
        printf("\t\t  文件不存在\n");
        return;
    }
    while (!feof(fp))
        if (fread(&a[m], LEN, 1, fp) == 1)
            m++;
    if (m == 0)
    {
        printf("\t\t  文件中没有记录");
        fclose(fp);
        return;
    }
    printf("\t\t  请输入要修改的联系人的电话号码:");
    scanf("%d", &nmb);
    for (i = 0; i < m; i++)
        if (nmb == a[i].num)    //检索是否有要相应的联系人
        {
            printf("\t\t  找到该名联系人,将修改他的信息!\n");
            printf("\t\t  电话:");
            scanf("%d", &a[i].num);
            printf("\t\t  姓名:");
            scanf("%s", &a[i].name);
            printf("\t\t  工作单位:");
            scanf("%s", &a[i].job);
            printf("\t\t  住址:");
            scanf("%s", &a[i].address);
            printf("\t\t  修改成功!");

            if ((fp = fopen("data.txt", "w+")) == NULL)
            {
                printf("\t\t  不能打开");
                return;
            }
            for (j = 0; j < m; j++)        //写入新的信息
                if (fwrite(&a[j], LEN, 1, fp) != 1)
                {
                    printf("\t\t  不能打开");
                    getch();
                }
            fclose(fp);
            break;
        }
    if (i == m)
        printf("\t\t  没有找到该名联系人");
}
void search()
{
    show();
    FILE* fp;
    int nmb, i, m = 0;
    if ((fp = fopen("data.txt", "r+")) == NULL)
    {
        fclose(fp);
        printf("\n\t\t  文件不存在!\n");
        return;
    }
    while (!feof(fp))
    {
        if (fread(&a[m], LEN, 1, fp) == 1)
            m++;
    }
    if (m == 0)
    {
        fclose(fp);
        printf("\n\t\t  文件没有记录!\n");
        return;
    }
    printf("\n\t\t  请输入联系人的电话号码!:");
    scanf("%d", &nmb);
    for (i = 0; i < m; i++)
        if (nmb == a[i].num)
        {
            printf("\t\t        电话         姓名         工作单位            住址                   \n");
            printf(FORMAT, DATA);
            break;
        }
    if (i == m)
        printf("\t\t  没有找到记录!\n");
    fclose(fp);
}
void show()
{
    FILE* fp;
    int i, m = 0;
    if ((fp = fopen("data.txt", "r+")) == NULL)
    {
        printf("\n\t\t  文件不存在\n");
        return;
    }
    while (!feof(fp))
    {
        if (fread(&a[m], LEN, 1, fp) == 1)
            m++;
    }
    fclose(fp);
    printf("\t\t  ---------------------------------------------------------------------------\n");
    printf("\t\t  ||    电话         姓名         工作单位            住址                 ||\n");
    for (i = 0; i < m; i++)
    {
        printf(FORMAT, DATA);
    }
    printf("\t\t  ---------------------------------------------------------------------------\n");
}
void insert()
{
    show();
    FILE* fp;
    int i, j, k, m = 0, nmb;
    if ((fp = fopen("data.txt", "r+")) == NULL)
    {
        printf("\t\t  文件不存在! \n");
        return;
    }
    while (!feof(fp))
        if (fread(&a[m], LEN, 1, fp) == 1)
            m++;
    if (m == 0)
    {
        printf("\t\t  文件中没有记录!\n");
        fclose(fp);
        return;
    }
    printf("\t\t  请输入要插入哪个号码的位置之后:");
    scanf("%d", &nmb);
    for (i = 0; i < m; i++)
        if (nmb == a[i].num)
            break;
    if (m == i)
    {
        printf("\t\t  没有找到改电话号码");
        fclose(fp);
        return;
    }
    for (j = m - 1; j > i; j--)
        a[j + 1] = a[j];
    printf("\t\t  请输入要插入的通讯录信息:\n");
    printf("\t\t  电话:");
    scanf("%d", &nmb);
    for (k = 0; k < m; k++)
        if (a[k].num == nmb)
        {
            printf("\t\t  电话已经存在,请按任意键继续!");
            getch();
            fclose(fp);
            return;
        }
    a[i + 1].num = nmb;
    printf("\t\t  姓名:");
    scanf("%s", &a[i + 1].name);
    printf("\t\t  工作:");
    scanf("%s", &a[i + 1].job);
    printf("\t\t  地址:");
    scanf("%s", &a[i + 1].address);
    printf("\t\t  插入成功,请输入任意键返回主界面!");
    if ((fp = fopen("data.txt", "w+")) == NULL)
    {
        printf("\t\t  不能打开!");
        return;
    }
    for (k = 0; k <= m; k++)
        if (fwrite(&a[k], LEN, 1, fp) != 1)
        {
            printf("\t\t  不能保存!");
            getch();
        }
    fclose(fp);
}
void order()
{
    FILE* fp;
    struct list b;
    int i = 0, j = 0, m = 0;
    printf("\n");
    if ((fp = fopen("data.txt", "r+")) == NULL)
    {
        printf("\t\t  文件不存在\n");
        return;
    }
    while (!feof(fp))
        if (fread(&a[m], LEN, 1, fp) == 1)
            m++;
    fclose(fp);
    if (m == 0)
    {
        printf("\t\t  文件中没有记录\n");
        return;
    }
    for (i = 0; i < m - 1; i++)
        for (j = i + 1; j < m; j++)
            if (a[i].num < a[j].num)
            {
                b = a[i]; a[i] = a[j]; a[j] = b;
            }
    if ((fp = fopen("data.txt", "w+")) == NULL)
    {
        printf("\t\t  文件不存在!\n");
        return;
    }
    for (i = 0; i < m; i++)
        if (fwrite(&a[i], LEN, 1, fp) != 1)
        {
            printf("\t\t  不能保存文件!\n");
            getch();
        }
    fclose(fp);
    show();
    printf("\t\t  保存成功\n");
}
void total()
{
    FILE* fp;
    int m = 0;
    if ((fp = fopen("data.txt", "r+")) == NULL)
    {
        printf("\t\t  文件不存在!\n");
        return;
    }
    while (!feof(fp))
        if (fread(&a[m], LEN, 1, fp) == 1)
            m++;
    if (m == 0)
    {
        printf("\n\t\t  没有联系人!\n");
        fclose(fp);
        return;
    }
    fclose(fp);
    show();
    printf("\t\t  您一共拥有 %d 位联系人", m);
}

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

相关文章

  • C++ 组合 (Composition)的介绍与实例

    C++ 组合 (Composition)的介绍与实例

    这篇文章主要给大家介绍了关于C++ 组合(Composition)的相关资料,组合就是将对象组合成树形结构以表示“部分-整体”的层次结构,使得用户对单个对象和组合对象的使用具有一致性。需要的朋友可以参考下
    2021-05-05
  • 详解如何从Matlab中导出清晰的结果图片

    详解如何从Matlab中导出清晰的结果图片

    写文章的时候有时需要matlab导出清晰的图片,如果直接用figure里面的保存的话不够清晰,下面这篇文章主要给大家介绍了关于如何从Matlab中导出清晰的结果图片的相关资料,需要的朋友可以参考下
    2022-06-06
  • Qt5实现文本编辑器(附详细代码)

    Qt5实现文本编辑器(附详细代码)

    QT是一个跨平台的GUI开发框架,我使用的QT5 C++版本的,本文主要介绍了Qt5实现文本编辑器,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07
  • C++自定义数据类型方法详情

    C++自定义数据类型方法详情

    这篇文章主要介绍了C++自定义数据类型方法详情,总结了两种方法,分别是typedef声明和枚举类型enum,相关内容需要的小伙伴可以参考下面文章内容,希望对你的学习有所帮助
    2022-03-03
  • C++中的数组、链表与哈希表

    C++中的数组、链表与哈希表

    这篇文章主要介绍了C++中的数组、链表与哈希表,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-09-09
  • C语言实现桶排序的方法示例

    C语言实现桶排序的方法示例

    这篇文章主要介绍了C语言实现桶排序的方法,简单描述了桶排序的概念、原理并结合实例形式分析了C语言实现桶排序算法的具体操作技巧,需要的朋友可以参考下
    2018-01-01
  • C++深入探究二阶构造模式的原理与使用

    C++深入探究二阶构造模式的原理与使用

    C++中经常会因为调用系统资源失败导致出现BUG,所以在类调用构造函数需要分配系统资源时会出现BUG,从而导致类对象虽然被创建,但是只是个半成品,为了避免这种情况需要使用二阶构造模式
    2022-04-04
  • C语言实现可增容动态通讯录详细过程

    C语言实现可增容动态通讯录详细过程

    这篇文章主要为大家介绍了C语言实现简易通讯录的完整流程,此通讯录还可以增容,并且每个环节都有完整代码,有需要的朋友可以借鉴参考下,希望能够有所帮助
    2022-05-05
  • 详解C++ STL vector容量(capacity)和大小(size)的区别

    详解C++ STL vector容量(capacity)和大小(size)的区别

    这篇文章主要介绍了详解C++ STL vector容量(capacity)和大小(size)的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-05-05
  • Linux系统下C语言中的标准IO总结

    Linux系统下C语言中的标准IO总结

    最近用到了C语言的标准IO库,由于对其中的一些细节不是非常清楚,导致了许多Bug,花了好长时间来调试,所以在此做个笔记,这篇文章主要给大家介绍了关于Linux系统下C语言中标准IO的相关资料,需要的朋友可以参考下
    2024-01-01

最新评论