设计一个简单个人电话号码查询系统

时间: 2023-12-29 15:04:51 浏览: 23
好的,我可以为您设计一个简单的个人电话号码查询系统。该系统的功能是允许用户输入一个人的姓名或电话号码,然后返回该人的电话号码或姓名。 以下是该系统的基本设计: 1. 创建数据库:创建一个数据库,其中包含两个字段:姓名和电话号码。 2. 添加数据:向数据库中添加一些数据,包括一些人的姓名和电话号码。 3. 用户输入:用户输入一个人的姓名或电话号码。 4. 查询数据:查询数据库以查找与输入匹配的记录。 5. 返回结果:如果找到匹配的记录,则返回该记录中的姓名和电话号码。如果找不到匹配的记录,则返回“未找到记录”。 6. 界面设计:可以使用简单的命令行界面或图形用户界面(GUI)来接收用户输入和显示结果。 需要注意的是,该系统只是一个简单的示例,还可以通过添加更多的功能和优化来进一步完善。
相关问题

设计一个简单个人电话号码查询系统给出其详细代码

好的,以下是一个简单的个人电话号码查询系统的详细代码,使用Python 3和SQLite3数据库: ```python import sqlite3 # 创建或连接到数据库 conn = sqlite3.connect('phonebook.db') # 创建表格 conn.execute('''CREATE TABLE IF NOT EXISTS phonebook (NAME TEXT PRIMARY KEY NOT NULL, PHONE TEXT NOT NULL);''') # 添加数据 conn.execute("INSERT INTO phonebook (NAME, PHONE) VALUES ('John Smith', '123-456-7890')") conn.execute("INSERT INTO phonebook (NAME, PHONE) VALUES ('Jane Doe', '555-555-5555')") # 提交更改 conn.commit() # 用户输入 search_term = input("Enter a name or phone number: ") # 查询数据库 cursor = conn.execute("SELECT * FROM phonebook WHERE NAME=? OR PHONE=?", (search_term, search_term)) result = cursor.fetchone() # 返回结果 if result: print("Name: " + result[0]) print("Phone: " + result[1]) else: print("Record not found.") # 关闭数据库连接 conn.close() ``` 这个系统创建了一个名为`phonebook.db`的SQLite3数据库,并在其中创建了一个名为`phonebook`的表格。然后,它向表格中添加了两个人的姓名和电话号码。接下来,用户可以输入一个人的姓名或电话号码,然后系统将查询数据库以查找与输入匹配的记录。最后,系统将返回匹配记录中的姓名和电话号码,或者如果找不到匹配的记录则返回“Record not found.”。

输入手机号查询信息C语言,简单个人电话号码查询系统.doc

很抱歉,我无法提供文档或软件下载。但是我可以给您一些思路,帮助您自己编写一个简单的个人电话号码查询系统。 首先,您需要一个存储电话号码和对应信息的数据库。您可以选择使用文件、数组或链表等数据结构来实现。为了方便,我们可以使用文件来存储这些信息。 其次,您需要设计一个菜单,让用户可以选择不同的功能,如添加电话号码、查询电话号码、删除电话号码等。根据用户的选择,您可以调用相应的函数来完成对应的操作。 以下是一个简单的示例代码,仅供参考: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #define MAX_NAME_LEN 20 #define MAX_PHONE_LEN 20 #define MAX_INFO_LEN 50 #define MAX_RECORDS 1000 // 定义电话号码记录结构体 typedef struct { char name[MAX_NAME_LEN]; char phone[MAX_PHONE_LEN]; char info[MAX_INFO_LEN]; } PhoneRecord; // 定义电话号码记录数组和记录数量 PhoneRecord records[MAX_RECORDS]; int recordCount = 0; // 从文件中加载电话号码记录 void loadRecords() { FILE *file = fopen("records.dat", "rb"); if (file == NULL) { return; } while (recordCount < MAX_RECORDS && fread(&records[recordCount], sizeof(PhoneRecord), 1, file) == 1) { recordCount++; } fclose(file); } // 保存电话号码记录到文件 void saveRecords() { FILE *file = fopen("records.dat", "wb"); if (file == NULL) { return; } for (int i = 0; i < recordCount; i++) { fwrite(&records[i], sizeof(PhoneRecord), 1, file); } fclose(file); } // 添加电话号码记录 void addRecord() { if (recordCount >= MAX_RECORDS) { printf("电话号码记录已满!\n"); return; } printf("请输入姓名:"); scanf("%s", records[recordCount].name); printf("请输入电话号码:"); scanf("%s", records[recordCount].phone); printf("请输入备注信息:"); scanf("%s", records[recordCount].info); recordCount++; saveRecords(); printf("电话号码记录已添加!\n"); } // 显示所有电话号码记录 void showRecords() { if (recordCount == 0) { printf("电话号码记录为空!\n"); return; } printf("%-20s%-20s%-50s\n", "姓名", "电话号码", "备注信息"); for (int i = 0; i < recordCount; i++) { printf("%-20s%-20s%-50s\n", records[i].name, records[i].phone, records[i].info); } } // 根据姓名查询电话号码记录 void searchRecord() { char name[MAX_NAME_LEN]; printf("请输入要查询的姓名:"); scanf("%s", name); int found = 0; for (int i = 0; i < recordCount; i++) { if (strcmp(records[i].name, name) == 0) { printf("%-20s%-20s%-50s\n", records[i].name, records[i].phone, records[i].info); found = 1; } } if (!found) { printf("未找到匹配的电话号码记录!\n"); } } // 根据姓名删除电话号码记录 void deleteRecord() { char name[MAX_NAME_LEN]; printf("请输入要删除的姓名:"); scanf("%s", name); int found = 0; for (int i = 0; i < recordCount; i++) { if (strcmp(records[i].name, name) == 0) { // 将后面的记录往前移动,覆盖当前记录 for (int j = i + 1; j < recordCount; j++) { memcpy(&records[j - 1], &records[j], sizeof(PhoneRecord)); } recordCount--; saveRecords(); printf("电话号码记录已删除!\n"); found = 1; break; } } if (!found) { printf("未找到匹配的电话号码记录!\n"); } } // 显示菜单 void showMenu() { printf("====================\n"); printf("电话号码查询系统\n"); printf("====================\n"); printf("1. 添加电话号码记录\n"); printf("2. 显示所有电话号码记录\n"); printf("3. 查询电话号码记录\n"); printf("4. 删除电话号码记录\n"); printf("0. 退出\n"); } int main() { loadRecords(); while (1) { showMenu(); int choice; printf("请选择功能:"); scanf("%d", &choice); switch (choice) { case 1: addRecord(); break; case 2: showRecords(); break; case 3: searchRecord(); break; case 4: deleteRecord(); break; case 0: printf("谢谢使用!\n"); return 0; default: printf("无效的选择!\n"); break; } } return 0; } ``` 请注意,这只是一个简单的示例代码,还有很多可以改进的地方。如果您希望实现更复杂的功能,可以考虑使用数据库或其他更高级的数据结构来存储电话号码记录。

相关推荐

简单个人电话号码查询系统(难度2) 【问题描述】 人们在日常生活中经常需要查找某个人或某个单位的电话号码,本实验将实现一个简单的个人电话号码查询系统,根据用户输人的信息(例如姓名等)进行快速查询。 【基本要求 】 ()在外存上,用文件保仔电话号码信息; 2)在内存中,设计数据结构存储电话号码信息; (3)提供查询功能:根据姓名实现快速查询; (4) 提供其他维护功能:例如插人、删除、修改等; 5)按电话号码进行排序。 【设计恩椇】 由于需要管理的电话号码信息较多,而且要在程序运行结束后仍然保存电话号 码信息,所以电话号码信息采用文件的形式存放到外存中。在系统运行时,需要将电话号码信息从文件调人内存来进行查找等操作,为了接收文件中的内容,要有一个数据结 const int max=10; struct TeleNumber string name; //4:2 string phoneNumber; 1固定电话号码 string mobileNumber; 1/移动电话号码 string email; 1/电子邮箱 1 Tele max; 为了实现对电话号码的快速查询,可以将上述结构数组排序,以便应用折半查找,但是,在数组中实现插人和州除操作的代价较高。如果记录需频繁进行插人或删除 操作,可以考虑采用二叉排序树组织电话号码信息,则查找和维护都能获得较高的时间性能。更复杂地,需要考虑该二叉排序树是否平衡,如何使之达到平衡。

最新推荐

recommend-type

6-10.py

6-10
recommend-type

基于机器学习的入侵检测系统+源码+说明.zip

基于机器学习的入侵检测系统+源码+说明.zip
recommend-type

matlab基于潜在低秩表示的红外与可见光图像融合.zip

matlab基于潜在低秩表示的红外与可见光图像融合.zip
recommend-type

4-5.py

4-5
recommend-type

基于tensorflow使用简单线性回归实现波士顿房价预测源码.zip

基于tensorflow使用简单线性回归实现波士顿房价预测源码.zip
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

2. 通过python绘制y=e-xsin(2πx)图像

可以使用matplotlib库来绘制这个函数的图像。以下是一段示例代码: ```python import numpy as np import matplotlib.pyplot as plt def func(x): return np.exp(-x) * np.sin(2 * np.pi * x) x = np.linspace(0, 5, 500) y = func(x) plt.plot(x, y) plt.xlabel('x') plt.ylabel('y') plt.title('y = e^{-x} sin(2πx)') plt.show() ``` 运行这段
recommend-type

JSBSim Reference Manual

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