用C语言完成带有文件操作的通讯录管理系统的设计与实现的完整代码

时间: 2023-08-30 15:12:19 浏览: 43
很抱歉,我并不能提供完整的代码,但我可以给你提供一个基本的框架,你可以根据自己的需求进行修改和完善。 ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #define MAX_NAME_LEN 20 #define MAX_PHONE_LEN 11 #define MAX_EMAIL_LEN 30 #define MAX_CONTACTS 1000 typedef struct { char name[MAX_NAME_LEN]; char phone[MAX_PHONE_LEN]; char email[MAX_EMAIL_LEN]; } Contact; Contact contacts[MAX_CONTACTS]; int num_contacts = 0; void load_contacts(char *filename) { FILE *fp = fopen(filename, "r"); if (fp == NULL) { printf("Error: Cannot open file '%s'!\n", filename); return; } while (!feof(fp)) { fscanf(fp, "%s %s %s", contacts[num_contacts].name, contacts[num_contacts].phone, contacts[num_contacts].email); num_contacts++; } fclose(fp); } void save_contacts(char *filename) { FILE *fp = fopen(filename, "w"); if (fp == NULL) { printf("Error: Cannot open file '%s'!\n", filename); return; } for (int i = 0; i < num_contacts; i++) { fprintf(fp, "%s %s %s\n", contacts[i].name, contacts[i].phone, contacts[i].email); } fclose(fp); } void list_contacts() { printf("Name\t\tPhone\t\tEmail\n"); for (int i = 0; i < num_contacts; i++) { printf("%-20s%-15s%-30s\n", contacts[i].name, contacts[i].phone, contacts[i].email); } } void add_contact() { if (num_contacts == MAX_CONTACTS) { printf("Error: The contacts list is full!\n"); return; } printf("Enter name: "); scanf("%s", contacts[num_contacts].name); printf("Enter phone: "); scanf("%s", contacts[num_contacts].phone); printf("Enter email: "); scanf("%s", contacts[num_contacts].email); num_contacts++; } void search_contact(char *name) { for (int i = 0; i < num_contacts; i++) { if (strcmp(contacts[i].name, name) == 0) { printf("Name\t\tPhone\t\tEmail\n"); printf("%-20s%-15s%-30s\n", contacts[i].name, contacts[i].phone, contacts[i].email); return; } } printf("Error: Cannot find contact '%s'!\n", name); } void delete_contact(char *name) { for (int i = 0; i < num_contacts; i++) { if (strcmp(contacts[i].name, name) == 0) { for (int j = i; j < num_contacts - 1; j++) { contacts[j] = contacts[j + 1]; } num_contacts--; printf("Contact '%s' has been deleted!\n", name); return; } } printf("Error: Cannot find contact '%s'!\n", name); } int main() { char filename[] = "contacts.txt"; load_contacts(filename); int choice; char name[MAX_NAME_LEN]; while (1) { printf("1. List contacts\n"); printf("2. Add contact\n"); printf("3. Search contact\n"); printf("4. Delete contact\n"); printf("5. Exit\n"); printf("Enter your choice: "); scanf("%d", &choice); switch (choice) { case 1: list_contacts(); break; case 2: add_contact(); break; case 3: printf("Enter name: "); scanf("%s", name); search_contact(name); break; case 4: printf("Enter name: "); scanf("%s", name); delete_contact(name); break; case 5: save_contacts(filename); exit(0); default: printf("Error: Invalid choice!\n"); break; } } return 0; } ``` 这个通讯录管理系统包括加载和保存通讯录文件、列出联系人、添加联系人、搜索联系人和删除联系人等功能。你可以根据需要对其进行修改和完善。

相关推荐

最新推荐

recommend-type

C语言数组实现学生信息管理系统设计

主要为大家详细介绍了C语言数组实现学生信息管理系统设计,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

C语言实现简单航班管理系统

主要为大家详细介绍了C语言实现简单航班管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

C语言实现班档案管理系统课程设计

主要为大家详细介绍了C语言实现班档案管理系统课程设计,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

C语言基于哈希表实现通讯录

主要为大家详细介绍了C语言基于哈希表实现通讯录,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

C语言实现餐饮结账管理系统

主要为大家详细介绍了C语言实现餐饮结账管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

list根据id查询pid 然后依次获取到所有的子节点数据

可以使用递归的方式来实现根据id查询pid并获取所有子节点数据。具体实现可以参考以下代码: ``` def get_children_nodes(nodes, parent_id): children = [] for node in nodes: if node['pid'] == parent_id: node['children'] = get_children_nodes(nodes, node['id']) children.append(node) return children # 测试数
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。