python實現(xiàn)手機通訊錄搜索功能
更新時間:2018年02月22日 11:58:35 作者:huo_1214
這篇文章主要介紹了python模仿手機通訊錄搜索功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了python通過輸入聯(lián)系人首字母查詢聯(lián)系人的具體代碼,供大家參考,具體內容如下
# -*- coding:utf-8 -*-
# 練習2:
# 模擬手機通訊錄搜索功能
class PERSON(object):
def __init__(self):
self.name_list = ['zhangsan', 'zhangsanfeng', 'zhaoliu', 'wangwu', 'wulong', 'wanda', 'lisi', 'liuyang','luoxiaoxiao', 'linmeimei', 'luhan', 'gaohairui', 'guojing', 'huangrong', 'hanhan']
#聲明空字典
self.ss_dict = {}
def total(self):
#for循環(huán)遍歷列表,取出每一個姓名
for name in self.name_list:
#取出首字母
s =name[0]
#判斷字典中是否有s這個key
if s not in self.ss_dict:
#如果沒有,根據(jù)key將存放name的列表放入字典
# s_list = []
# s_list.append(name)
# self.ss_dict[s] = s_list
self.ss_dict[s] = [name]
else:
#如果有,根據(jù)key取出列表,將這個name添加到列表
s_list = self.ss_dict[s]
s_list.append(name)
print(self.ss_dict)
def add_person(self):
name = input('請輸入姓名:')
if name not in self.name_list:
self.name_list.append(name)
s = name[0]
if s not in self.ss_dict:
self.ss_dict[s] = [name]
else:
s_list = self.ss_dict[s]
s_list.append(name)
else:
print('已存在!')
def query_person(self):
s = input('請輸入要查找聯(lián)系人名字的首字母:')
# s就是要查找的字典的key
if s not in self.ss_dict:
print('不存在')
else:
# 根據(jù)這個key取出字典中對應的值(列表)
s_list = self.ss_dict[s]
for index,name in enumerate(s_list):
print('序號:%s 姓名:%s' % (index,name))
# for x in range(0,len(s_list)):
# name = s_list[x]
# print('序號:%s 姓名:%s'%(x,name))
return s
def alter_person(self):
s= self.query_person()
index = int(input('請輸入要修改聯(lián)系人的序號:'))
new_name = input('輸入更改后的名字(%s):'%self.ss_dict[s][index])
del self.ss_dict[s][index]
s = new_name[0]
if s not in self.ss_dict:
self.ss_dict[s] = [new_name]
else:
s_list = self.ss_dict[s]
s_list.append(new_name)
def delete_person(self):
while len(self.ss_dict) == '0':
print('信息為空!')
print('1.根據(jù)名字刪除')
print('2.全部刪除')
print('0.退出')
num = int(input('輸入序號:'))
while num not in range(0,3 ):
num = int(input('選項不存在,請重輸:'))
if num == 1:
s = self.query_person()
index = int(input('請輸入要刪除聯(lián)系人的序號:'))
rs = input('是否真的要刪除,(y/n):')
if rs == 'y':
self.ss_dict[s].pop(index)
print('刪除成功')
else:
print('取消刪除')
elif num == 2:
rs = input('是否真的要刪除,(y/n):')
if rs == 'y':
self.ss_dict.clear()
print('刪除成功')
else:
print('取消刪除')
else:
return
def start(self):
self.total()
while 1:
print('1.添加聯(lián)系人')
print('2.查詢聯(lián)系人')
print('3.修改聯(lián)系人')
print('4.刪除聯(lián)系人')
print('0.退出')
num = int(input('輸入序號:'))
while num not in range(0,5):
num = int(input('選項不存在,請重輸:'))
if num == 1:
self.add_person()
elif num == 2:
self.query_person()
elif num == 3:
self.alter_person()
elif num == 4:
self.delete_person()
else:
break
p = PERSON()
p.start()
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
python 回調函數(shù)和回調方法的實現(xiàn)分析
這篇文章主要介紹了python 回調函數(shù)和回調方法的實現(xiàn)分析,需要的朋友可以參考下2016-03-03
Python3 requests文件下載 期間顯示文件信息和下載進度代碼實例
這篇文章主要介紹了Python3 requests文件下載 期間顯示文件信息和下載進度代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-08-08
Pandas中df.loc[]與df.iloc[]的用法與異同?
本文主要介紹了Pandas中df.loc[]與df.iloc[]的用法與異同,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧?2022-07-07
Python實現(xiàn)圖的廣度和深度優(yōu)先路徑搜索算法
圖是一種抽象數(shù)據(jù)結構,本質和樹結構是一樣的。圖與樹相比較,圖具有封閉性,可以把樹結構看成是圖結構的前生。本文將利用Python實現(xiàn)圖的廣度和深度優(yōu)先路徑搜索算法,感興趣的可以學習一下2022-04-04
Python接口自動化淺析pymysql數(shù)據(jù)庫操作流程
本文主要介紹pymysql安裝、操作流程、語法基礎及封裝操作數(shù)據(jù)庫類,需要的朋友可以參考下,希望能對大家有所幫助,每日提升一點點,歡迎大家多多交流討論2021-08-08

