python實現(xiàn)簡單通訊錄管理系統(tǒng)
本文實例為大家分享了python實現(xiàn)通訊錄管理系統(tǒng)的具體代碼,供大家參考,具體內容如下
=====歡迎使用通訊錄管理系統(tǒng)=====
1.添加
2.修改
3.冊除
4.查詢
5.排序
6.退出
=========================
請選擇你要執(zhí)行的操作的序號,具體要求:
1)通訊錄要以文件的形式存儲在硬盤上(比如D:\tongxunlu) ,每一條數(shù)據(jù)(聯(lián)系人姓名和手機號碼)存儲一行,如果一個聯(lián)系人有多個手機號,則都存儲在同一行,即通訊錄中每個聯(lián)系入的數(shù)據(jù)占一行。
2)系統(tǒng)運行時初始菜單如上,根據(jù)用戶選擇的序號執(zhí)行相應的操作:
添加功能:提醒角戶輸入姓名和手機號碼,同時進行手機號碼格式檢查,合法則該姓名和手機號碼插入到通訊錄最后一行。
修改功能:根據(jù)用戶指定的聯(lián)系人姓名修改其手機號碼,修改后保存文件。 刪除功能:根據(jù)用戶輸人的姓名刪除該條記錄。
查詢功能:可以根據(jù)聯(lián)系人姓名查詢其手機號,也可以根據(jù)手機號查詢聯(lián)系人姓名。 排序功能:要求用戶選擇按聯(lián)系人姓名升序或降序,對通訊錄進行排序。
退出功能:結束程序的運行。 注意:只有選擇序號6(退出)時,程序的運行才會結束,否則一直循環(huán)等待用戶進行增刪改查操作。
這里我利用openpyxl對Excel操作
源碼:
from openpyxl import load_workbook
fn = r'd:\tongxunlu.xlsx'
# 打印操作菜單
def showMenu():
? ? print("========歡迎使用通訊錄管理系統(tǒng)========")
? ? 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位數(shù)字!")
? ? ? ? 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位數(shù)字!")
? ? ? ? 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)
# 循環(huán)函數(shù)
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("輸入的序號不在范圍內!")以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
基于python分享一款地理數(shù)據(jù)可視化神器keplergl
這篇文章主要介紹了分享一款地理數(shù)據(jù)可視化神器keplergl,keplergl是由Uber開源的一款地理數(shù)據(jù)可視化工具,通過keplergl我們可以在Jupyter?notebook中使用,下文分享需要的小伙伴可以參考一下2022-02-02
python 遞歸深度優(yōu)先搜索與廣度優(yōu)先搜索算法模擬實現(xiàn)
這篇文章主要介紹了python 遞歸深度優(yōu)先搜索與廣度優(yōu)先搜索算法模擬實現(xiàn) ,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-10-10
python批量檢查兩個對應的txt文件的行數(shù)是否一致的實例代碼
這篇文章主要介紹了python批量檢查兩個對應的txt文件的行數(shù)是否一致,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-10-10
Python基于分析Ajax請求實現(xiàn)抓取今日頭條街拍圖集功能示例
這篇文章主要介紹了Python基于分析Ajax請求實現(xiàn)抓取今日頭條街拍圖集功能,涉及Python針對今日頭條URL請求與json數(shù)據(jù)處理相關操作技巧,需要的朋友可以參考下2018-07-07

