python实现通讯录管理系统

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

题目

期末项目

一. 项目要求

利用函数实现通讯录管理系统,通讯录的内容包含姓名、联系方式、微信号、电子邮箱等需要保存的信息。至少要包含姓名和联系方式两种。管理系统的功能包括信息的添加、删除、修改、查询、显示、保存的功能。

二.项目步骤

1.使用自定义函数实现每个功能

(1)功能菜单:显示项目应该具有的功能
(2)添加:输入要添加的信息 
(3)删除:输入要删除的联系人姓名,删除其所有的信息
(4)修改:输入要修改的联系人姓名,修改其信息
(5)查询:输入要查询的联系人姓名,遍历列表,得到其信息
(6)显示:显示所有的联系人信息
(7)保存:将数据保存到文件中
(8)主函数:先显示菜单,提示用户输入要进行的操作代码,调用相应的函数

2. 当添加、删除、修改了信息后,要同步保存到文件中

用列表作为全局变量,当列表信息发生变化,调用保存函数

3.编写一个模块,在主函数中调用该模块,测试其功能。完成一个,测试一个,保证所有模块能正确运行,信息存储在文本文件中。

4.可以用列表,元组,字典存储通讯录信息。假如,现在只存储姓名和手机号,这里选择字典,转换为元组放在列表里保存。

5.初始时,先创建了一个文本文件,文件名为学生姓名,并输入空列表[]。

三、项目代码要求:

1. 代码要有必要的注释,说明其功能。
2. 要有每个模块的测试结果。
3. 若有截图,截图要清晰。

代码

1.代码说明

题目要求从模块中调用函数,因此需要在同一个文件夹下建立两个python文件:manage.py和main.py. 其中,manage.py中设计函数,main.py中调用manage.py中的函数并实现功能。

2.manage.py

'''
注意:
1.要求输入的姓名默认全部为合理输入,并未对输入内容进行判断和过滤
2.默认打开的文件已经存在,并没对文件状态进行判断,而是以列表信息中是否存在该学生为依据
3.没有使用字典的任何操作
4.如果希望将所有学生信息保存在同一个txt文件中,只需将每个函数中file_name重新命名的部分注释掉
5.修改信息采用的方法是:将原内容删除,并重新写入新内容,这么做的原因是电脑要没电了,这个可以作为自己的测试板块,重新设计编写
6.实验步骤的最后一步 不知道是什么目的,并所以没有这样做
7.因为都是采用列表来判断学生内容,所以文件保存成功后重新运行程序列表清空,即不可再查询到信息
8.打印所有信息可以采取文件夹下多文件读取的方法,遍历该目录下的所有txt文件,读出内容并打印,请自行编写

2021/6/16

新增注意:
1.修改文件内容时,如果将姓名一同修改,则会出现文件名与文件内容中的姓名不同的情况
2.修改文件内容时,如果将该姓名修改为另一个已经出现过的姓名,在列表中将会出现重名情况
3.先没有处理重名情况的操作
4.同名情况下,如果修改该名字的信息,则将修改第一次出现该名称的位置的信息
5.因此,如果错误1和错误2同时发生,文件就会,嗯...串了,就乱套了

'''

#d = {}  #字典储存信息

Student = []
path = "D:\\"  #文件保存路径 默认为空即保存在当前文件夹下 建议新建文件夹并修改路径
file_name = path + "student.txt" #文件默认保存位置

#显示命令
def print_message():
    print("**************************************")
    print("     **1.添加学生信息")
    print("     **2.删除学生信息")
    print("     **3.修改学生信息")
    print("     **4.查找学生信息")
    print("     **5.查看所有信息")
    print("     **6.查看操作菜单")

#添加信息
def add():
        print("请输入需要添加到姓名、手机号,以空格隔开:")
        #列表
        A = input().split(" ")
        temp_str = ""
        for i in A:
            temp_str += i+"  "
        if temp_str != '/n': #防止错误输入
             Student.append(A)  #加入列表
             file_name = path+A[0] +".txt"
             print(temp_str, file=open(file_name, 'w'))  #创建文件,并写入文件  如果存在同名文件,则原内容会被覆盖
        #字典
        # A = input().split(" ")
        # Name.append(A[0])
        # d[A[0]] = A[1]
        # print("添加成功")
        # save(A[0])  # 更新学生信息

#删除信息
def delete():
    print("请输入需要删除的姓名:")
    name = input()
    #字典删除
    # del d[name]
    # Name.remove(name)
    #从文件中删除学生信息
    exist = 0
    for i in range(len(Student)):
        #存在该学生
        if Student[i].count(name) > 0:
            if name == Student[i][0]:
                file_name = path + name + ".txt"
                #删除列表中的信息
                Student.pop(i)
                #删除文件中的信息
                lines = [l for l in open(file_name, "r") if l.find(name, 0, len(name)) != 0] #暂时的删除方式
                fd = open(file_name, "w")                                                    #如: 要删除'张三‘,但‘张三四'也会被删除
                fd.writelines(lines)
                fd.close()
                print("删除成功")
                exist = 1  #判断学生是否存在的标签
                break
        else :
            exist = 0
    if exist == 0:
         print("未找到该学生的信息!")

def delete_2(name,f_n):
      # 从列表里删除该学生
        for i in range(len(Student)):
            # 存在该学生
            if Student[i].count(name) > 0:
                if name == Student[i][0]:
                    del Student[i]
                    break

        #从文件中删除学生信息
        lines = [l for l in open(f_n, "r") if l.find(name, 0, len(name)) != 0]
        fd = open(f_n, "w")
        fd.writelines(lines)
        fd.close()

#查询信息
def search():
    print("请输入需要查询的姓名:")
    name  = input()
    #字典查询
    #print("查询结果:",name,d[name])
    exist = 0
    for i in range(len(Student)):
        #存在该学生 这一步判断有点多余 但是为了简化打印未找到的结果还是这样做了
        if Student[i].count(name) > 0:
            if name == Student[i][0]:
                print("查询结果: ")
                for temp in Student[i]:
                    print(temp,end=" ")
                print()
                exist = 1  # 判断学生是否存在的标签
                break
        else:
                exist = 0
    if exist == 0:
                print("未找到该学生的信息!")

#更改文件信息
def change_file():
    print("输入需要修改信息的学生姓名:")
    name = input()
    exist = 0
    for i in range(len(Student)):
        #存在该学生
        if Student[i].count(name) > 0:
            if name == Student[i][0]:
                # 找到了该学生
                # 下面进行修改信息的操作
                file_name = path + name + ".txt"
                print("输入修改后该学生的所有信息:")
                A = input().split(" ")
                temp_str = ""
                for i in A:
                    temp_str += i + "  "
                if temp_str != '/n':  # 防止错误输入
                    Student.append(A)  # 加入列表
                    delete_2(name,file_name) # 先删除该信息

                    print(temp_str, file=open(file_name, 'a'))  # 创建文件,并重新写入文件
                print("修改成功")
                exist = 1  # 判断学生是否存在的标签
                break
        else:
                exist = 0
    if exist == 0:
                print("未找到该学生的信息!")

#显示信息
def printf():
    print("所有信息如下:")
    for i in Student:
        for j in i:
            print(j,end=" ")
        print()

3.main.py

import manage

print("**************************************")
print("    欢迎来到学生信息管理系统")
manage.print_message() #打印命令指令
print("**************************************")
while(True):

    print("请输入需要执行的操作(输入'q‘退出程序):")
    choice = input()
    if choice == '1':
        manage.add()   #增
    if choice == '2':
       manage.delete() #删
    if choice == '3':
       manage.change_file()  #改
    if choice == '4':
       manage.search()  #查
    if choice == '5':
       manage.printf()  #打印
    if choice == '6':
        manage.print_message()  # 打印命令指令
    if choice == 'q':
        print("退出!")
        break

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

(0)

相关推荐

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

  • Python实现通讯录功能

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

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

    本文实例为大家分享了python实现通讯录管理系统的具体代码,供大家参考,具体内容如下 =====欢迎使用通讯录管理系统=====1.添加2.修改3.册除4.查询5.排序6.退出========================= 请选择你要执行的操作的序号,具体要求: 1)通讯录要以文件的形式存储在硬盘上(比如D:\tongxunlu) ,每一条数据(联系人姓名和手机号码)存储一行,如果一个联系人有多个手机号,则都存储在同一行,即通讯录中每个联系入的数据占一行. 2)系统运行时初始菜单如上,根据

  • 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写一个简单的通讯录 一.构思 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实现命令行通讯录实例教程

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

  • 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实现手机通讯录搜索功能

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

随机推荐