Python 基于列表实现的通讯录管理系统(有完整源码)

news2025/1/15 14:22:37

目录

通讯录管理系统

PersonInformation类

ContactList类

main函数

程序的运行流程

完整代码

运行示例


通讯录管理系统

这是一个基于文本的界面程序,用户可以通过命令行与之交互,它使用了CSV文件来存储和读取联系人信息,这使得数据可以持久化保存。此外,程序还提供了一些基本的输入验证,以确保输入的数据是有效的。

它包含了两个类PersonInformation类用于创建和管理个人信息对象,而ContactList类则用于管理这些对象的集合。

PersonInformation

这个类用于存储一个人的基本信息,包括姓名、性别、年龄、电话和住址。它有一个__str__方法,用于定义当对象被转换为字符串时的表现形式。

class PersonInformation:
    def __init__(self, name, gender, age, telephone, address):
        self.name = name
        self.gender = gender
        self.age = age
        self.telephone = telephone
        self.address = address

    def __str__(self):
        return f"名字: {self.name}, 性别: {self.gender}, 年龄: {self.age}, 电话: {self.telephone}, 住址: {self.address}"

ContactList

这个类用于管理一个联系人列表。它提供了以下功能:

  • 添加联系人(add_contact
  • 删除联系人(remove_contact
  • 查找联系人(find_contact
  • 修改联系人信息(modify_contact
  • 显示所有联系人(show_contacts
  • 保存联系人到CSV文件(save_contacts
  • 从CSV文件加载联系人(load_contacts
class ContactList:
    def __init__(self):
        self.arr = []

    def add_contact(self, person):
        self.arr.append(person)
        self.save_contacts()

    def is_empty(self):
        if not self.arr:
            print("当前联系人列表为空!")

    def remove_contact(self, name):
        person = self.find_contact(name)
        if person:
            self.arr.remove(person)
            self.save_contacts()
            print("删除成功!")
            self.is_empty()
        else:
            print("此联系人不存在!")

    def show_contacts(self):
        print('通讯录:')
        for person in self.arr:
            print(person)
        self.is_empty()

    def find_contact(self, name):
        for person in self.arr:
            if person.name == name:
                return person
        return None

    def modify_contact(self, old_name, new_info):
        person = self.find_contact(old_name)
        if person:
            person.name = new_info.name
            person.gender = new_info.gender
            person.age = new_info.age
            person.telephone = new_info.telephone
            person.address = new_info.address
            self.save_contacts()
            print("修改成功!\n ", person)
        else:
            print("此联系人不存在!")

    def save_contacts(self, filename="contacts.csv"):
        with open(filename, 'w', newline='', encoding='utf-8') as f:
            writer = csv.writer(f)
            writer.writerow(['姓名', '性别', '年龄', '电话', '住址'])
            for person in self.arr:
                writer.writerow([person.name, person.gender, person.age, person.telephone, person.address])

    def load_contacts(self, filename="contacts.csv"):
        if not os.path.isfile(filename):
            with open(filename, 'w', newline='', encoding='utf-8') as f:
                writer = csv.writer(f)
                writer.writerow(['姓名', '性别', '年龄', '电话', '住址'])
        with open(filename, 'r', newline='', encoding='utf-8') as f:
            reader = csv.reader(f)
            next(reader)
            for row in reader:
                if len(row) == 5:
                    name, gender, age, telephone, address = row
                    self.add_contact(PersonInformation(name, gender, age, telephone, address))
                else:
                    print(f"跳过不完整的联系人记录: {row}")

这个函数用于显示程序的菜单选项,让用户可以选择执行不同的操作。

main函数

这是程序的主入口,它首先创建一个ContactList实例,然后进入一个无限循环,不断显示菜单并根据用户的选择调用相应的方法。当用户选择退出时,程序会结束。

程序的运行流程

  1. 程序启动后,首先加载已有的联系人信息。
  2. 显示菜单,等待用户输入选择。
  3. 根据用户的选择执行相应的操作:
    • 添加联系人:输入新的联系人信息并添加到列表中。
    • 删除联系人:输入要删除的联系人姓名,然后从列表中删除。
    • 查找联系人:输入要查找的联系人姓名,并显示其信息。
    • 修改联系人:输入要修改的联系人姓名,然后输入新的信息进行修改。
    • 显示所有联系人:列出当前所有的联系人信息。
    • 退出通讯录:退出程序。

完整代码

import os, csv

class PersonInformation:
    def __init__(self, name, gender, age, telephone, address):
        self.name = name
        self.gender = gender
        self.age = age
        self.telephone = telephone
        self.address = address

    def __str__(self):
        return f"名字: {self.name}, 性别: {self.gender}, 年龄: {self.age}, 电话: {self.telephone}, 住址: {self.address}"

class ContactList:
    def __init__(self):
        self.arr = []

    def is_full(self):
        return self.num == self.capacity

    def add_contact(self, person):
        self.arr.append(person)
        self.save_contacts()

    def is_empty(self):
        if not self.arr:
            print("当前联系人列表为空!")

    def remove_contact(self, name):
        person = self.find_contact(name)
        if person:
            self.arr.remove(person)
            self.save_contacts()
            print("删除成功!")
            self.is_empty()
        else:
            print("此联系人不存在!")

    def show_contacts(self):
        print('通讯录:')
        for person in self.arr:
            print(person)
        self.is_empty()

    def find_contact(self, name):
        for person in self.arr:
            if person.name == name:
                return person
        return None

    def modify_contact(self, old_name, new_info):
        person = self.find_contact(old_name)
        if person:
            person.name = new_info.name
            person.gender = new_info.gender
            person.age = new_info.age
            person.telephone = new_info.telephone
            person.address = new_info.address
            self.save_contacts()
            print("修改成功!\n ", person)
        else:
            print("此联系人不存在!")

    def save_contacts(self, filename="contacts.csv"):
        with open(filename, 'w', newline='', encoding='utf-8') as f:
            writer = csv.writer(f)
            writer.writerow(['姓名', '性别', '年龄', '电话', '住址'])
            for person in self.arr:
                writer.writerow([person.name, person.gender, person.age, person.telephone, person.address])

    def load_contacts(self, filename="contacts.csv"):
        if not os.path.isfile(filename):
            with open(filename, 'w', newline='', encoding='utf-8') as f:
                writer = csv.writer(f)
                writer.writerow(['姓名', '性别', '年龄', '电话', '住址'])
        with open(filename, 'r', newline='', encoding='utf-8') as f:
            reader = csv.reader(f)
            next(reader)
            for row in reader:
                if len(row) == 5:
                    name, gender, age, telephone, address = row
                    self.add_contact(PersonInformation(name, gender, age, telephone, address))
                else:
                    print(f"跳过不完整的联系人记录: {row}")

def menu(contact_list):
    print()
    print("*********************************")
    print("** 1、增加联系人 2、删除联系人 **")
    print("** 3、查找联系人 4、修改联系人 **")
    print("** 5、展示联系人 0、退出通讯录 **")
    print("*********************************")

def main():
    contact_list = ContactList()
    contact_list.load_contacts()
    while True:
        menu(contact_list)
        name, gender, age, telephone, address = [""]*5
        input_choice = input("请输入您的选择:")
        if input_choice == '1':
            while len(name)<2:
                name = input("请输入您要添加的联系人的姓名:\n")
                if contact_list.find_contact(name):
                    print(f'此姓名[{name}]已存在!')
                    break
                while gender not in ('男','女','1','0'):
                    gender = input("请输入性别(1-男, 0-女):\n")
                    if gender=='1': gender = '男'
                    elif gender=='0': gender = '女'
                while not age.isnumeric():
                    age = input("请输入年龄:\n")
                while telephone is None or len(telephone)!=11 or not telephone.startswith('1'):
                    telephone = input("请输入手机号:\n")
                while len(address)<6:
                    address = input("请输入住址(字数不少于6):\n")
                contact_list.add_contact(PersonInformation(name, gender, age, telephone, address))
                print("联系人添加成功!")
        elif input_choice == '2':
            name = input("请输入您要删除的联系人的名字:\n")
            contact_list.remove_contact(name)
        elif input_choice == '3':
            name = input("请输入您要查找的联系人的名字:\n")
            person = contact_list.find_contact(name)
            print(person if person else "此联系人不存在!")
        elif input_choice == '4':
            old_name = input("请输入您要修改的联系人的名字:\n")
            new_info = PersonInformation(*([""]*5))
            person = contact_list.find_contact(old_name)
            if person:
                print('待修改联系人:(直接回车保留原字段)\n ', person)
                while len(new_info.name)<2:
                    new_info.name = input("请输入新的名字:\n")
                    if new_info.name=="":
                        new_info.name = person.name
                    elif contact_list.find_contact(name):
                        print(f'此姓名[{name}]已存在,退出修改!')
                        break
                    while new_info.gender not in ('男','女','1','0'):
                        new_info.gender = input("请输入性别(1-男, 0-女):\n")
                        if new_info.gender=='1': new_info.gender = '男'
                        elif new_info.gender=='0': new_info.gender = '女'
                        elif new_info.gender=="":  new_info.gender = person.gender
                    while not new_info.age.isnumeric():
                        new_info.age = input("请输入年龄:\n")
                        if new_info.age=="": new_info.age = person.age
                    while len(new_info.telephone)!=11 or not new_info.telephone.startswith('1'):
                        new_info.telephone = input("请输入新的手机号:\n")
                        if new_info.telephone=="": new_info.telephone = person.telephone
                    while len(new_info.address)<6:
                        new_info.address = input("请输入新的住址(字数不少于6):\n")
                        if new_info.address=="": new_info.address = person.address
                contact_list.modify_contact(old_name, new_info)
        elif input_choice == '5':
            contact_list.show_contacts()
        elif input_choice == '0':
            print("成功退出通讯录!")
            break
        else:
            print("输入错误,请重新选择!")

if __name__ == "__main__":
    main()

运行示例

*********************************
** 1、增加联系人 2、删除联系人 **
** 3、查找联系人 4、修改联系人 **
** 5、展示联系人 0、退出通讯录 **
*********************************
请输入您的选择:5
通讯录:
当前联系人列表为空!

*********************************
** 1、增加联系人 2、删除联系人 **
** 3、查找联系人 4、修改联系人 **
** 5、展示联系人 0、退出通讯录 **
*********************************
请输入您的选择:1
请输入您要添加的联系人的姓名:
Hann
请输入性别(1-男, 0-女):
1
请输入年龄:
51
请输入手机号:
13962600000
请输入住址(字数不少于6):
江苏省昆山市
联系人添加成功!

*********************************
** 1、增加联系人 2、删除联系人 **
** 3、查找联系人 4、修改联系人 **
** 5、展示联系人 0、退出通讯录 **
*********************************
请输入您的选择:5
通讯录:
名字: Hann, 性别: 男, 年龄: 51, 电话: 13962600000, 住址: 江苏省昆山市

*********************************
** 1、增加联系人 2、删除联系人 **
** 3、查找联系人 4、修改联系人 **
** 5、展示联系人 0、退出通讯录 **
*********************************
请输入您的选择:1
请输入您要添加的联系人的姓名:
Hann
此姓名[Hann]已存在!

*********************************
** 1、增加联系人 2、删除联系人 **
** 3、查找联系人 4、修改联系人 **
** 5、展示联系人 0、退出通讯录 **
*********************************
请输入您的选择:1
请输入您要添加的联系人的姓名:
YangCheng
请输入性别(1-男, 0-女):
1
请输入年龄:
22
请输入手机号:
13962611111
请输入住址(字数不少于6):
江苏省昆山市
联系人添加成功!

*********************************
** 1、增加联系人 2、删除联系人 **
** 3、查找联系人 4、修改联系人 **
** 5、展示联系人 0、退出通讯录 **
*********************************
请输入您的选择:5
通讯录:
名字: Hann, 性别: 男, 年龄: 51, 电话: 13962600000, 住址: 江苏省昆山市
名字: YangCheng, 性别: 男, 年龄: 22, 电话: 13962611111, 住址: 江苏省昆山市

*********************************
** 1、增加联系人 2、删除联系人 **
** 3、查找联系人 4、修改联系人 **
** 5、展示联系人 0、退出通讯录 **
*********************************
请输入您的选择:4
请输入您要修改的联系人的名字:
Hann
待修改联系人:(直接回车保留原字段)
  名字: Hann, 性别: 男, 年龄: 51, 电话: 13962600000, 住址: 江苏省昆山市
请输入新的名字:
HannYang
请输入性别(1-男, 0-女):

请输入年龄:

请输入新的手机号:

请输入新的住址(字数不少于6):

修改成功!
  名字: HannYang, 性别: 男, 年龄: 51, 电话: 13962600000, 住址: 江苏省昆山市

*********************************
** 1、增加联系人 2、删除联系人 **
** 3、查找联系人 4、修改联系人 **
** 5、展示联系人 0、退出通讯录 **
*********************************
请输入您的选择:5
通讯录:
名字: HannYang, 性别: 男, 年龄: 51, 电话: 13962600000, 住址: 江苏省昆山市
名字: YangCheng, 性别: 男, 年龄: 22, 电话: 13962611111, 住址: 江苏省昆山市

*********************************
** 1、增加联系人 2、删除联系人 **
** 3、查找联系人 4、修改联系人 **
** 5、展示联系人 0、退出通讯录 **
*********************************
请输入您的选择:3
请输入您要查找的联系人的名字:
hannyang
此联系人不存在!

*********************************
** 1、增加联系人 2、删除联系人 **
** 3、查找联系人 4、修改联系人 **
** 5、展示联系人 0、退出通讯录 **
*********************************
请输入您的选择:3
请输入您要查找的联系人的名字:
HannYang
名字: HannYang, 性别: 男, 年龄: 51, 电话: 13962600000, 住址: 江苏省昆山市

*********************************
** 1、增加联系人 2、删除联系人 **
** 3、查找联系人 4、修改联系人 **
** 5、展示联系人 0、退出通讯录 **
*********************************
请输入您的选择:2
请输入您要删除的联系人的名字:
hann
此联系人不存在!

*********************************
** 1、增加联系人 2、删除联系人 **
** 3、查找联系人 4、修改联系人 **
** 5、展示联系人 0、退出通讯录 **
*********************************
请输入您的选择:2
请输入您要删除的联系人的名字:
HannYang
删除成功!

*********************************
** 1、增加联系人 2、删除联系人 **
** 3、查找联系人 4、修改联系人 **
** 5、展示联系人 0、退出通讯录 **
*********************************
请输入您的选择:5
通讯录:
名字: YangCheng, 性别: 男, 年龄: 22, 电话: 13962611111, 住址: 江苏省昆山市

*********************************
** 1、增加联系人 2、删除联系人 **
** 3、查找联系人 4、修改联系人 **
** 5、展示联系人 0、退出通讯录 **
*********************************
请输入您的选择:0
成功退出通讯录!


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1572887.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C++进阶--C++11(2)

C11第一篇 C11是C编程语言的一个版本&#xff0c;于2011年发布。C11引入了许多新特性&#xff0c;为C语言提供了更强大和更现代化的编程能力。 可变参数模板 在C11中&#xff0c;可变参数模板可以定义接受任意数量和类型参数的函数模板或类模板。它可以表示0到任意个数&…

数据库基础:概念、分类、作用和特点

文章目录 概要DB-Engines 排名数据库的分类数据库的作用数据库的特点数据库的应用小结 概要 数据库是按照数据结构来组织、存储和管理数据的仓库。它是一个长期存储在计算机内的、有组织的、可共享的、统一管理的大量数据的集合。数据库可以被视为电子化的文件柜&#xff0c;用…

40.基于SpringBoot + Vue实现的前后端分离-摄影分享网站(项目 + 论文)

项目介绍 随着互联网时代的发展&#xff0c;传统的线下管理技术已无法高效、便捷的管理信息。为了迎合时代需求&#xff0c;优化管理效率&#xff0c;各种各样的管理系统应运而生&#xff0c;国家在环境要求不断提高的前提下&#xff0c;摄影分享网站管理系统建设也逐渐进入了信…

Lanelets_ 高效的自动驾驶地图表达方式

Lanelets: 高效的自动驾驶地图表达方式 附赠自动驾驶学习资料和量产经验&#xff1a;链接 LaneLets是自动驾驶领域高精度地图的一种高效表达方式&#xff0c;它以彼此相互连接的LaneLets来描述自动驾驶可行驶区域&#xff0c;不仅可以表达车道几何&#xff0c;也可以完整表述车…

考研高数(平面图形的面积,旋转体的体积)

1.平面图形的面积 纠正&#xff1a;参数方程求面积 2.旋转体的体积&#xff08;做题时&#xff0c;若以x为自变量不好计算&#xff0c;可以求反函数&#xff0c;y为自变量进行计算&#xff09;

正排索引 vs 倒排索引 - 搜索引擎具体原理

阅读导航 一、正排索引1. 概念2. 实例 二、倒排索引1. 概念2. 实例 三、正排 VS 倒排1. 正排索引优缺点2. 倒排索引优缺点3. 应用场景 三、搜索引擎原理1. 宏观原理2. 具体原理 一、正排索引 1. 概念 正排索引是一种索引机制&#xff0c;它将文档或数据记录按照某种特定的顺序…

【cpp】快速排序优化

标题&#xff1a;【cpp】快速排序 水墨不写bug 正文开始&#xff1a; 快速排序的局限性&#xff1a; 虽然快速排序是一种高效的排序算法&#xff0c;但也存在一些局限性&#xff1a; 最坏情况下的时间复杂度&#xff1a;如果选择的基准元素不合适&#xff0c;或者数组中存在大…

“张衡一号”卫星成功监测太阳活动引起的空间天气事件

太阳出现耀斑和日冕物质抛射等短时间尺度的剧烈活动&#xff0c;造成地球磁层、电离层和中高层大气的强烈扰动&#xff0c;这类活动通常称之为空间天气事件。空间天气事件会对现代高技术系统&#xff0c;如航空、航天、导航通信、电力油气管网等&#xff0c;造成严重影响&#…

Rust---复合数据类型之元组

目录 元组的使用输出结果 元组的使用 fn main() {// 创建一个元组let my_tuple : (i32, &str, f64) (10, "hello", 3.14);// 打印元组中的元素println!("{:?}", my_tuple);// 访问元组中的元素let first_element my_tuple.0; // 访问第一个元素let…

阿里云最新活动及优惠券领取指南

随着云计算技术的快速发展&#xff0c;越来越多的企业选择将业务部署在云平台上。阿里云作为国内领先的云服务提供商&#xff0c;不断推出各种优惠活动及优惠券&#xff0c;旨在帮助用户降低成本&#xff0c;提升运营效率。本文将为大家详细介绍阿里云的最新活动及优惠券领取指…

Web3 游戏周报(3.24-3.30)

【3.24-3.30】Web3 游戏行业动态&#xff1a; Web3 开发平台 Mirror World 在 Solana 上推出首个游戏 rollup 链 NFT 卡牌游戏 Parallel 完成 3,500 万美元融资&#xff0c;Solana Ventures 等参投 加密游戏开发公司 Gunzilla Games 完成 3,000 万美元融资 Telegram 游戏 No…

第四百四十四回

文章目录 1. 问题描述2. 优化方法2.1 缩小范围2.2 替代方法 3. 示例代码4. 内容总结 我们在上一章回中介绍了"如何获取AppBar的高度"相关的内容&#xff0c;本章回中将介绍关于MediaQuery的优化.闲话休提&#xff0c;让我们一起Talk Flutter吧。 1. 问题描述 我们在…

(二)小案例银行家应用程序-创建DOM元素

● 上图的数据很明显是从我们账户数组中拿到了&#xff0c;我们刚刚学习了forEach&#xff0c;所以我们使用forEach来创建我们的DOM元素&#xff1b; const displayMovements function (movements) {movements.forEach((mov, i) > {const type mov > 0 ? deposit : w…

161 Linux C++ 通讯架构实战15,线程池代码分析

线程池应该使用的地方 和 epoll 技术结合 线程池代码处理数据的地方。 线程池分析&#xff1a; 线程池代码1 threadpool_create //Tencent8888 start threadpool_create函数的目的初始化线程池&#xff0c;对应的struct是 threadpool_t /* 1.先malloc整个线程池的大小 2.这里…

常见的加密方式总结(哈希算法、对称、非对称)

哈希算法是一种用数学方法对数据生成一个固定长度的唯一标识的技术&#xff0c;可以用来验证数据的完整性和一致性&#xff0c;常见的哈希算法有 MD、SHA、MAC 等。 对称加密算法是一种加密和解密使用同一个密钥的算法&#xff0c;可以用来保护数据的安全性和保密性&#xff0…

顺序表相关习题

&#x1f308; 个人主页&#xff1a;白子寰 &#x1f525; 分类专栏&#xff1a;python从入门到精通&#xff0c;魔法指针&#xff0c;进阶C&#xff0c;C语言&#xff0c;C语言题集&#xff0c;C语言实现游戏&#x1f448; 希望得到您的订阅和支持~ &#x1f4a1; 坚持创作博文…

GIT版本管理使用示例

一、创建好远程代码仓库后&#xff0c;复制远程仓库的地址 二、新建一个文件夹&#xff0c;在文件夹里打开Git Bash Here 三、输入git clone 远程仓库地址&#xff0c;仓库就初始化完成了 四、新建一个文本文件&#xff0c;假设这是我们开发的代码 五、打开文本&#xff0c;假设…

边界值设计测试用例

​ 边界值分析法&#xff08;Boundary Value Analysis&#xff0c;BVA&#xff09;的测试用例来自于等价类的边界&#xff0c;是等价类划分法的补充。根据边界值划分法&#xff0c;等价类分析法中的测试数据不是选取等价类中的典型值或任意值&#xff0c;而是应当选取正好等于、…

【Matlab】Matlab 汉/英语(A/a)声学特征比较与基音频率分析(源码+音频文件)【独一无二】

&#x1f449;博__主&#x1f448;&#xff1a;米码收割机 &#x1f449;技__能&#x1f448;&#xff1a;C/Python语言 &#x1f449;公众号&#x1f448;&#xff1a;测试开发自动化【获取源码商业合作】 &#x1f449;荣__誉&#x1f448;&#xff1a;阿里云博客专家博主、5…

物联网实战--入门篇之(八)嵌入式-空气净化器

目录 一、风扇调速 二、通讯协议 三、净化器运行逻辑 一、风扇调速 单片机是不能直接驱动电机的&#xff0c;因为主芯片的驱动电流比较小(50mA左右)&#xff0c;他们之间正常还要有个电机驱动器&#xff0c;常用的有TB6612、L298和L9110等&#xff0c;目前项目用的这个电机它…