python实现简单通讯录管理系统

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

=====欢迎使用通讯录管理系统=====
1.添加
2.修改
3.册除
4.查询
5.排序
6.退出
=========================

请选择你要执行的操作的序号,具体要求:

1)通讯录要以文件的形式存储在硬盘上(比如D:\tongxunlu) ,每一条数据(联系人姓名和手机号码)存储一行,如果一个联系人有多个手机号,则都存储在同一行,即通讯录中每个联系入的数据占一行。

2)系统运行时初始菜单如上,根据用户选择的序号执行相应的操作:

添加功能:提醒角户输入姓名和手机号码,同时进行手机号码格式检查,合法则该姓名和手机号码插入到通讯录最后一行。
修改功能:根据用户指定的联系人姓名修改其手机号码,修改后保存文件。 删除功能:根据用户输人的姓名删除该条记录。
查询功能:可以根据联系人姓名查询其手机号,也可以根据手机号查询联系人姓名。 排序功能:要求用户选择按联系人姓名升序或降序,对通讯录进行排序。
退出功能:结束程序的运行。 注意:只有选择序号6(退出)时,程序的运行才会结束,否则一直循环等待用户进行增删改查操作。

这里我利用openpyxl对Excel操作

源码:

from openpyxl import load_workbook

fn = r'd:\tongxunlu.xlsx'

# 打印操作菜单
def showMenu():
    print("========欢迎使用通讯录管理系统========")
    print("     1.添加")
    print("     2.修改")
    print("     3.删除")
    print("     4.查询")
    print("     5.排序")
    print("     6.退出")
    print("==================================")

# 打开文件
def openFile():
    wb = load_workbook(fn)
    ws = wb.active
    return ws, wb

# 判断手机号是否合法
def isLegal(s):
    if len(s) == 11 and s.isdigit():
        return True
    else:
        return False

# 添加手机号
def addData():
    data = input("输入姓名和号码(空格分开):").split(" ")
    for i in range(len(data), 1, -1):                # 从最后一个手机号开始
        s = isLegal(data[i - 1])
    if not s:
        print("手机号码必须为11位数字!")
        addData()
    else:
        w1, w2 = openFile()
        w1.append(data)
        print("添加成功!")
        w2.save(fn)

# 更改手机号
def changeData():
    flag = False
    data = input("请输入需要修改的姓名和新的手机号码(空格分开):").split(" ")
    if not isLegal(data[1]):
        print("手机号码必须为11位数字!")
        changeData()
    else:
        w1, w2 = openFile()
        for row in w1.rows:
            if row[0].value == data[0]:
                flag = True
                row[1].value = data[1]
        if not flag:
            print("通讯录中没有此人!")
            changeData()
        else:
            print("修改成功!")
            w2.save(fn)

# 删除人
def delete():
    flag = False
    x = 0
    name = input("请输入要删除的姓名:")
    w1, w2 = openFile()
    for row in w1.rows:
        x += 1
        if row[0].value == name:
            flag = True
            w1.delete_rows(x)
    if not flag:
        print("通讯录中没有此人!")
    else:
        print("删除成功!")
        w2.save(fn)

# 查找手机号或者姓名
def search():
    flag = False
    data = input("请输入姓名或手机号码:")
    w1, w2 = openFile()
    for row in w1.rows:
        if row[0].value == data:
            flag = True
            print(row[1].value)
            if row[2].value is not None:
                print(row[2].value)
        elif row[1].value == data or row[2].value == data:
            flag = True
            print(row[0].value)
    if not flag:
        print("通讯录中没有此人或手机号!")
        search()

# 排序
def sort():
    s = input("请输入正序或逆序(正序输入F,逆序输入T):")
    if s == "F":
        flag = False
    elif s == "T":
        flag = True
    data = []
    w1, w2 = openFile()
    for row in w1.rows:
        data1 = []
        for cell in row:
            data1.append(cell.value)
        data.append(data1)
    data.sort(key=lambda x: x[0], reverse=flag)
    w2.remove(w1)
    w1 = w2.create_sheet()
    for i in data:
        w1.append(i)
    w2.save(fn)

# 循环函数
while True:
    showMenu()
    num = int(input("请输入操作序号:"))
    if num == 1:
        addData()
    elif num == 2:
        changeData()
    elif num == 3:
        delete()
    elif num == 4:
        search()
    elif num == 5:
        sort()
    elif num == 6:
        print("再见!")
        break
    else:
        print("输入的序号不在范围内!")

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

(0)

相关推荐

  • python实现学生通讯录管理系统

    本文实例为大家分享了python实现学生通讯录管理系统的具体代码,供大家参考,具体内容如下 功能模块分析: 1.首页(菜单功能) 2.添加学生 3.删除学生 4.修改学生 5.统计通讯录联系人人数 6.获取所有学生通讯信息 代码如下: def main(): while True: menu() number = int(input("请输入需要实现的操作的序号:")) if number==1: insert() #添加学生 if number==2: delete() #删除学生

  • Python实现通讯录功能

    说实话,第一次写这么长的Python代码,期间遇到了很多问题,但是,最终还是完成了,花了我一天半的时间. 该程序实现了用户的增,删,改,查,主要用到sqlite3模块.对于该模块的知识点,请查看我的另一篇文章SQLite-Python 如有更好的建议,请私信,本人将不胜荣幸,让我们一起来学习Python! #-*- coding:utf-8 -*- import sqlite3 #打开本地数据库用于存储用户信息 conn = sqlite3.connect('mysql_person.db')

  • Python实现命令行通讯录实例教程

    1.实现目标 编写一个命令行通讯录程序,可以添加.查询.删除通讯录好友及电话 2.实现方法 创建一个类来表示一个人的信息.使用字典存储每个人的对象,名字作为键. 使用pickle模块永久地把这些对象存储下来. 使用字典内建的方法添加.删除修改人员信息. 3.思维导图 4.编写伪代码 # 1.创建字典用来存储通讯录信息 # 2.创建人员类,包含姓名.关系.电话三个属性 # 3.创建操作类,包含增加.查询.删除人员,退出,保存并退出五个方法 # 4.程序运行 # 5.判断通讯录文件是否存在 # 6.

  • python实现通讯录系统

    本文实例为大家分享了python实现通讯录系统的具体代码,供大家参考,具体内容如下 一.首先,给大家看一下这个系统的主菜单效果 如下: 二.步骤分析 1.首先创建一个main.py文件: main.py: #导入管理系统模块 from managerSystem import ContactManager #启动管理系统 if __name__=='__main__':     contact_manager=ContactManager()     contact_manager.run()

  • python实现通讯录管理系统

    本文实例为大家分享了python实现通讯录管理系统的具体代码,供大家参考,具体内容如下 题目 期末项目 一. 项目要求 利用函数实现通讯录管理系统,通讯录的内容包含姓名.联系方式.微信号.电子邮箱等需要保存的信息.至少要包含姓名和联系方式两种.管理系统的功能包括信息的添加.删除.修改.查询.显示.保存的功能. 二.项目步骤 1.使用自定义函数实现每个功能 (1)功能菜单:显示项目应该具有的功能(2)添加:输入要添加的信息 (3)删除:输入要删除的联系人姓名,删除其所有的信息(4)修改:输入要修改

  • 如何用Python写一个简单的通讯录

    目录 用Python写一个简单的通讯录 一.构思 1.定义空列表和一个空字典来存储 2.定义功能选项 3.添加通讯录功能 3.2 删除学员功能 二.整体项目演示 用Python写一个简单的通讯录 一.构思 1.定义空列表和一个空字典来存储 list1=[] #用于储存字典中的信息 dict1={} #用于储存联系人信息 2.定义功能选项 def Menu(): print('请选择功能--------\n' '1.添加学员\n' '2.删除学员\n' '3.修改学员\n' '4.查询学员\n'

  • 一个简单的python程序实例(通讯录)

    核心代码: 复制代码 代码如下: #!/usr/bin/python#Filename:friendbook.pyimport cPickle as pimport sysimport timeimport os ab={'Xdex':'cneds@fnedf.com',        'Laexly':'fev@fe.com',        'Fukc':'fexok@ver.com',        'Stifu':'stif@qq.com'} def Dumpfile(list):   

  • python数据库编程 Mysql实现通讯录

    本文实例为大家分享了Mysql实现通讯录的具体代码,供大家参考,具体内容如下 #-*-code:utf-8-*- import pymysql def CreateTable(): hcon=pymysql.connect(host='localhost',user='root',password='lptpwd',database='contract',charset='utf8') hcur=hcon.cursor() hcur.execute('drop table if exists c

  • python数据库编程 ODBC方式实现通讯录

    Python 数据库编程,ODBC方式实现通讯录,供大家参考,具体内容如下 #-*-coding:utf-8-*- import pyodbc import os def SelectInfo(hcon,hcur): hcur.execute('select * from PassMapT') ptitle=('ID','Item','Pwd','other') print(ptitle) result=hcur.fetchall() for item in result: print(item

  • python实现手机通讯录搜索功能

    本文实例为大家分享了python通过输入联系人首字母查询联系人的具体代码,供大家参考,具体内容如下 # -*- coding:utf-8 -*- # 练习2: # 模拟手机通讯录搜索功能 class PERSON(object): def __init__(self): self.name_list = ['zhangsan', 'zhangsanfeng', 'zhaoliu', 'wangwu', 'wulong', 'wanda', 'lisi', 'liuyang','luoxiaoxi

随机推荐