Python用字典構(gòu)建多級(jí)菜單功能
相關(guān)知識(shí)點(diǎn):
#key-value
#字典是無(wú)序的,因?yàn)樗麤](méi)有下標(biāo),通過(guò)key找
info={
'stu01':"liuhaolai",
'stu02':"wangshulin"
}
print(info['stu01'])
info['stu03']='劉**'#若不存在該key,則直接添加
info['stu04']='王##'
print(info)
#del
del info['stu03']
print(info)
#pop
info.pop('stu04')
print(info)
print(info.get('stu03'))#不確定字典里有沒(méi)有時(shí)用
print('stu01' in info)#判斷有沒(méi)有
print(info.values())#打印值
print(info.keys())#打印key
#字典的嵌套
place={
'遼寧':{
'大連':['很漂亮','很干凈'],
'沈陽(yáng)':['很大','有些亂'],
'阜新':['很小','很安逸']
},
'江蘇':{
'南京':['省會(huì)','性?xún)r(jià)比極低'],
'蘇州':['古今結(jié)合','小橋流水'],
'鎮(zhèn)江':['有些亂','一般般']
}
}
print("------")
print(place)
place['江蘇']['鎮(zhèn)江'][1]='一般般啦'
print(place)
print(place.values())#打印值
print(place.keys())#打印key
place.setdefault('河北',{'唐山:[0,1]'})#查,沒(méi)有就添加,和get不同
print(place)
print(place.setdefault('江蘇',{'蘇州:[0,1]'}))#查,沒(méi)有就添加
info={
'stu01':"liuhaolai",
'stu02':"wangshulin",
'stu03':'lucky',
'stu04':'pangpang'
}
new={
'stu01':'david',
'stu02':'tree',
'stu05':'lala'
}
new.setdefault('stu03','david')#查,沒(méi)有就添加
print(new)
info.update(new)#將已有的覆蓋更新,沒(méi)有的創(chuàng)建
print(info)
print(info.items())#字典轉(zhuǎn)成列表
c=dict.fromkeys([6,7,8],[1,{"name":'number'}])#初始化一個(gè)新字典
print(c)
#字典的循環(huán)
info2={
'stu01':"liuhaolai",
'stu02':"wangshulin",
'stu03':'lucky',
'stu04':'pangpang'
}
print(info2.get('stu01'))
print(info2.setdefault('stu01'))
for i in info2:#推薦!?。。。?!
print(i,info[i])
print("------")
for k,v in info2.items():#效果一樣,但低效
print(k,v)
--------------------------------------------------------------------------------
正文:
需求:
1.三級(jí)菜單
2.可依次選擇進(jìn)入各子菜單
3.按b逐級(jí)返回,按q退出
# Author:David Liu
# Be Happy!
place={
'遼寧1':{
'大連':{
'甘井子區(qū)':['大連理工大學(xué)'],
'沙河口區(qū)':['數(shù)碼廣場(chǎng)']
},
},
'遼寧2':{
'沈陽(yáng)': {
'皇姑區(qū)': ['遼寧大學(xué)'],
'鐵西區(qū)': ['小樹(shù)林']
},
},
'遼寧3':{
'阜新': {
'海州區(qū)':['胖胖來(lái)'],
'細(xì)河區(qū)':['細(xì)河區(qū)人民政府']
}
}
}
exit_flag=True
while exit_flag:
for i in place:
print(i)
choice=input("選擇進(jìn)入,按q退出>>")
if choice in place:
while exit_flag:
for i2 in place[choice]:
print('\t',i2)
choice2=input("選擇進(jìn)入,按b返回,按q退出>>")
if choice2 in place[choice]:
while exit_flag:
for i3 in place[choice][choice2]:
print('\t\t', i3)
choice3 = input("選擇進(jìn)入,按b返回,按q退出>>")
if choice3 in place[choice][choice2]:
for i4 in place[choice][choice2][choice3]:
print('\t\t\t',i4)
choice4 = input("最后一層,按b返回,按q退出>>")
if choice4=='b':
pass#沒(méi)用,占位的
elif choice4=='q':
exit_flag = False
if choice3 == 'b':
break
elif choice3 == 'q':
exit_flag = False
if choice2 == 'b':
break
elif choice2 == 'q':
exit_flag = False
elif choice == 'q':
exit_flag = False
print('\n',"已退出!".center(50,'-'))
ps:下面看下Python字典實(shí)現(xiàn)三級(jí)菜單
################################################
# Task Name: 三級(jí)菜單 #
# Description:打印省、市、縣三級(jí)菜單 #
# 可返回上一級(jí) #
# 可隨時(shí)退出程序 #
#----------------------------------------------#
# Author:Oliver Lee #
################################################
zone = {
'山東' : {
'青島' : ['四方','黃島','嶗山','李滄','城陽(yáng)'],
'濟(jì)南' : ['歷城','槐蔭','高新','長(zhǎng)青','章丘'],
'煙臺(tái)' : ['龍口','萊山','牟平','蓬萊','招遠(yuǎn)']
},
'江蘇' : {
'蘇州' : ['滄浪','相城','平江','吳中','昆山'],
'南京' : ['白下','秦淮','浦口','棲霞','江寧'],
'無(wú)錫' : ['崇安','南長(zhǎng)','北塘','錫山','江陰']
},
'浙江' : {
'杭州' : ['西湖','江干','下城','上城','濱江'],
'寧波' : ['海曙','江東','江北','鎮(zhèn)海','余姚'],
'溫州' : ['鹿城','龍灣','樂(lè)清','瑞安','永嘉']
},
'安徽' : {
'合肥' : ['蜀山','廬陽(yáng)','包河','經(jīng)開(kāi)','新站'],
'蕪湖' : ['鏡湖','鳩江','無(wú)為','三山','南陵'],
'蚌埠' : ['蚌山','龍子湖','淮上','懷遠(yuǎn)','固鎮(zhèn)']
},
'廣東' : {
'深圳' : ['羅湖','福田','南山','寶安','布吉'],
'廣州' : ['天河','珠海','越秀','白云','黃埔'],
'東莞' : ['莞城','長(zhǎng)安','虎門(mén)','萬(wàn)江','大朗']
}
}
province_list = list(zone.keys()) #省列表
# flag = False
# flag1 = False
while True:
print(" 省 ".center(50,'*'))
for i in province_list:
print(province_list.index(i)+1,i) #打印省列表
pro_id = input("請(qǐng)輸入省編號(hào),或輸入q(quit)退出:") #省ID
if pro_id.isdigit():
pro_id = int(pro_id)
if pro_id > 0 and pro_id <= len(province_list):
pro_name = province_list[pro_id-1] #根據(jù)省ID獲取省名稱(chēng)
city_list = list(zone[pro_name].keys()) #根據(jù)省名稱(chēng)獲取對(duì)應(yīng)的值,從新字典中獲取key,即市列表
while True:
print(" 市 ".center(50,'*'))
for v in city_list:
print(city_list.index(v)+1,v) #打印市列表
city_id = input("請(qǐng)輸入市編號(hào),或輸入b(back)返回上級(jí)菜單,或輸入q(quit)退出:")
if city_id.isdigit():
city_id = int(city_id)
if city_id > 0 and city_id <= len(city_list):
city_name = city_list[city_id-1] #根據(jù)市ID獲取市名稱(chēng)
town_list = zone[pro_name][city_name] #根據(jù)省名稱(chēng)獲取對(duì)應(yīng)的值,從新字典中獲取值,即縣列表
while True:
print(" 縣 ".center(50,'*'))
for j in town_list:
print(town_list.index(j)+1,j)
back_or_quit = input("輸入b(back)返回上級(jí)菜單,或輸入q(quit)退出:")
if back_or_quit == 'b':
break #終止此層while循環(huán),跳轉(zhuǎn)到上一層While。
elif back_or_quit == 'q':
# flag1 = True
# break #根據(jù)標(biāo)志位結(jié)束程序。
exit()
else:
print("輸入非法!")
else:
print("編號(hào)%d不存在。"%city_id)
elif city_id == 'b':
break
elif city_id == 'q':
# flag = True
# break
exit()
else:
print("輸入非法!")
# if flag1:
# break
else:
print("編號(hào)%d不存在。"%pro_id)
elif pro_id == 'q':
break
else:
print("輸入非法!")
# if flag or flag1:
# break
總結(jié)
以上所述是小編給大家介紹的Python用字典構(gòu)建多級(jí)菜單功能,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
相關(guān)文章
pycharm運(yùn)行OpenCV項(xiàng)目踩坑記錄
本文主要介紹了在PyCharm中運(yùn)行OpenCV項(xiàng)目時(shí)遇到的問(wèn)題及其解決方法,具有一定的參考價(jià)值,感興趣的可以了解一下2025-03-03
細(xì)數(shù)nn.BCELoss與nn.CrossEntropyLoss的區(qū)別
今天小編就為大家整理了一篇細(xì)數(shù)nn.BCELoss與nn.CrossEntropyLoss的區(qū)別,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-02-02
python使用回溯算法實(shí)現(xiàn)列表全排列
這篇文章主要介紹了python使用回溯算法實(shí)現(xiàn)列表全排列,研究的問(wèn)題是輸入列表L(不含重復(fù)元素),輸出L的全排列,全排列問(wèn)題,可以用回溯法解決,需要的朋友可以參考下2023-11-11
Python實(shí)現(xiàn)Linux系統(tǒng)上CI/CD工作流的方法詳解
在現(xiàn)代軟件開(kāi)發(fā)中,持續(xù)集成(CI)和持續(xù)部署(CD)是提高開(kāi)發(fā)效率、保證代碼質(zhì)量的重要手段,下面我們來(lái)看看如何使用Python實(shí)現(xiàn)Linux系統(tǒng)的CI/CD工作流吧2025-04-04
pyodps中的apply用法及groupby取分組排序第一條數(shù)據(jù)
這篇文章主要介紹了pyodps中的apply用法及groupby取分組排序第一條數(shù)據(jù),問(wèn)綻放圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值需要的小伙伴可以參考一下2022-05-05
Python實(shí)現(xiàn)刪除列表中滿(mǎn)足一定條件的元素示例
這篇文章主要介紹了Python實(shí)現(xiàn)刪除列表中滿(mǎn)足一定條件的元素,結(jié)合具體實(shí)例形式對(duì)比分析了Python針對(duì)列表元素的遍歷、復(fù)制、刪除等相關(guān)操作技巧,需要的朋友可以參考下2017-06-06
詳解Python中RegEx在數(shù)據(jù)處理中的應(yīng)用
正則表達(dá)式(Regular?Expressions,簡(jiǎn)稱(chēng)?RegEx)是一種強(qiáng)大的文本匹配和搜索工具,它在數(shù)據(jù)處理、文本解析和字符串操作中發(fā)揮著關(guān)鍵作用,下面就跟隨小編一起來(lái)了解一下RegEx的具體使用吧2024-01-01
Python類(lèi)型轉(zhuǎn)換的魔術(shù)方法詳解
這篇文章主要介紹了Python類(lèi)型轉(zhuǎn)換的魔術(shù)方法詳解,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12

