Python 三级菜单与优化(一层循环嵌套)
优化的思路是使用单层循环嵌套完成三级菜单,这个优化思路我非常喜欢,我喜欢在编程的时候用最少的东西写出同样的效果,通常这样会绕来绕去,但非常有趣!!!
需求:
1、运行程序输出第一级菜单;
2、选择一级菜单某项,输出二级菜单,同理输出三级菜单;
3、让用户选择是否要退出;
4、有返回上一级菜单的功能;
多层循环嵌套:
data = {
'A':{
"Aa":['Aa1','Aa2','Aa3'],
"Ab":['Ab1','Ab2','Ab3'],
"Ac":['Ac1','Ac2','Ac3']
},
'B':{
"Ba":['Ba1','Ba2','Ba3'],
"Bb":['Bb1','Bb2','Bb3'],
"Bc":['Bc1','Bc2','Bc3']
},
'C':{
"Ca":['Ca1','Ca2','Ca3'],
"Cb":['Cb1','Cb2','Cb3'],
"Cc":['Cc1','Cc2','Cc3']
}
}
jump = True #跳出循环直至退出程序
print("特别提醒:选‘q’退出;选‘b’返回上一级菜单!!")
while jump == True:
for i in data:
print(i)
choice = input("请选择进入:")
if choice in data:
while jump == True:
for i1 in data[choice]:
print(i1)
choice1 = input("请选择进入:")
if choice1 in data[choice]:
while jump == True:
for i2 in data[choice][choice1]:
print(i2)
choice2 = input("请选择退出或返回上一菜单:")
if choice2 == 'q':
jump = False
elif choice2 == 'b':
break
else:
print("选择错误请重新选择:")
elif choice1 == 'q':
jump = False
elif choice1 == 'b':
break
else:
print("选择错误请重新选择:")
elif choice == "q":
jump = False
else:
print("选择错误请重新选择:")
print ("退出程序...")
三级菜单
单层循环嵌套:
data = {
'A':{
"Aa":['Aa1','Aa2','Aa3'],
"Ab":['Ab1','Ab2','Ab3'],
"Ac":['Ac1','Ac2','Ac3']
},
'B':{
"Ba":['Ba1','Ba2','Ba3'],
"Bb":['Bb1','Bb2','Bb3'],
"Bc":['Bc1','Bc2','Bc3']
},
'C':{
"Ca":['Ca1','Ca2','Ca3'],
"Cb":['Cb1','Cb2','Cb3'],
"Cc":['Cc1','Cc2','Cc3']
}
}
list_menu = []
flag = True
while flag:
if len(list_menu) == 0:
info = data
else:
info = list_menu[-1]
for i in info:
print (i)
choice = input("请选择进入:").strip()
if choice == 'q':
break
if choice == 'b':
if len(list_menu) == 0:
print("已经是最高级菜单!!")
continue
list_menu.pop()
continue
if len(list_menu) == 0:
list_menu.append(info[choice])
continue
list_menu.append(list_menu[-1][choice])
print("退出程序...")
三级菜单
Python 三级菜单与优化(一层循环嵌套)的更多相关文章
- python(5)- 简单练习:python三级菜单优化
python三级菜单优化,菜鸟版链接:http://www.cnblogs.com/xuyaping/p/6648170.html menu = { '北京':{ '海淀':{ '五道口':{ 'so ...
- python三级菜单实例(傻瓜版和进阶版)
程序: python三级菜单 要求: : 1.打印省.市.县三级菜单 2.可返回上一级 3.可随时退出程序 方案一:傻瓜版(其实傻瓜版考察的主要是思路!思路清楚了,那才不是傻瓜!O(∩_∩)O哈哈~) ...
- python 三级菜单 while循环三次,湖北省市-县-街道的选择,3个while的循环 -day2
python编写一个三级while的循环菜单 1.定义字典,字典里面嵌套字典,内嵌字典的值为列表. 思路: 湖北省的市:字典中的定义3个字典,用于存储{序列-键:市名} shiqu_dir = {} ...
- python 三级菜单
三级列表: menu = { '北京':{ '海淀':{ '五道口':{ 'soho':{}, '网易':{}, 'google':{} }, '中关村':{ '爱奇艺':{}, '汽车之家':{}, ...
- python三级菜单的实现
一.作业要求 1.使用字典实现三级菜单功能 2.直接输入前面数字进入下一级菜单 3.按B返回上一级,按Q退出 二.需要知识点 1.if循环 2.for循环,enumerate的用法 3.while循环 ...
- Python 三级菜单 增强版
需要实现的功能是:三级菜单1.从文本内读出选项2.查询每一级的选项,并能对选项进行增/删/改功能3.每一级可以退出程序或者返回上一层 2018-5-14 更新内容 思路 实现过程中的BUG及解决方案: ...
- 4th,Python三级菜单
1. 运行程序输出第一级菜单 2. 选择一级菜单某项,输出二级菜单,同理输出三级菜单 3. 菜单数据保存在文件中 4. 让用户选择是否要退出 5. 有返回上一级菜单的功能 data = { '北京': ...
- python三级菜单
#-*- coding:utf-8 -*-#Author:gxli #一级菜单项def menu(): #遍历字典dic一级菜单 print('-----------一级菜单------------- ...
- Python——三级菜单
#三级菜单函数 menu = { '北京':{ 海淀:{ '五道口':{} '中关村':{} '上帝':{} } '昌平':{} '朝阳':{} '东城':{} }, '上海':{} '山东':{} ...
随机推荐
- 【解题报告】pojP1436 Horizontally Visible Segments
http://poj.org/problem?id=1436 题目大意:有n条平行于x轴的线段,每条线段有y坐标,如果两条线段有一段x坐标数值相等,且中间没有其它线段阻隔,则称这两条线段"照 ...
- jQuery获取Select选择的Text和Value
jQuery获取Select选择的Text和Value:语法解释:1. $("#select_id").change(function(){//code...}); //为S ...
- 4001: [TJOI2015]概率论
4001: [TJOI2015]概率论 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 262 Solved: 108[Submit][Status] ...
- 3360: [Usaco2004 Jan]算二十四
3360: [Usaco2004 Jan]算二十四 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 6 Solved: 6[Submit][Statu ...
- 双系统删除Ubuntu后出现grub界面而无法正常启动Windows系统的解决方法
第一次安装双系统的时候由于不怎么会弄,设置了ubuntu引导windows,这种方法是非常不推荐的,因为当ubuntu出现问题或者是当你不再使用ubuntu的时候,删除ubuntu就会成为一个很麻烦的 ...
- "the hypervisor is not running" 故障
在我们日常服务器管理中,常常会遇到创建虚拟机,如果在一台新部署的 Hyper-V 上新建一个 Virtual Machine 时,出现错误信息:"The virtual machine co ...
- GitHub中最强大的iOS Notifications和AlertView框架,没有之一!
FFToast是一个非常强大的iOS message notifications和AlertView扩展.它可以很容易实现从屏幕顶部.屏幕底部和屏幕中间弹出一个通知.你可以很容易的自定义弹出的View ...
- CSS -- 练习(待续优化)
啊啊啊 错误百出啊 错点总结: 字符全角半角.清楚浮动.结尾</div>有点乱找不到对应的了.注释要写好. <!DOCTYPE html> <html lang=&qu ...
- 基于ThinkPHP 5.0与Vue.JS 2.x的前后端开源开发框架VueThink
VueThink 项目介绍 VueThink是一套基于Vue全家桶(Vue2.x + Vue-router2.x + Vuex)+ Thinkphp的前后端分离框架. 脚手架构建也可以通过vue官方的 ...
- cookie技术简介
Cookie简介 众所周知,HTTP协议是一个无状态的协议.一个Web应用由很多个Web页面组成,每个页面都有唯一的URL来定义.用户在浏览器的地址栏输入页面的URL,浏览器就会向Web Server ...