young -> simple
  三级菜单超简单,每层都是小循环
  小可爱,不是if就是for,真可爱

def menu(message):
print('按q返回上一层')
print('按e退出')
ec = 'q' # 返回上一级
ex = 'e' for i in message: # 打印一级菜单
print(i) while True: # 进入一级菜单选择
choice1 = input('请输入1>>>:')
if choice1 in message: # 判断是否在字典中
for i1 in message[choice1]:
print(i1) # 打印值 while True:
choice2 = input('请输入2>>>:') # 进入二级菜单选择
if choice2 in message[choice1]:
for i2 in message[choice1][choice2]:
print(i2) while True:
choice3 = input('请输入3>>>:') # 进入三级菜单选择
if choice3 in message[choice1][choice2]:
for i3 in message[choice1][choice2][choice3]:
print(i3) elif choice3 == ec: # 返回判断
for i2 in message[choice1]:
print(i2) # 打印上一级菜单
break elif choice3 == ex: # 退出判断
exit('退出中……ing')
else:
print('输入错误,请重新输入,么么哒') elif choice2 == ec: # 返回判断,并打印上一级菜单
for i1 in message:
print(i1)
break
elif choice2 == ex: # 退出判断
exit('退出中……ing')
else:
print('输入错误,请重新输入,么么哒') elif choice1 == ec: # 返回判断
print('已经最顶级菜单,完全退出请输入 e ')
continue
elif choice1 == ex: # 退出判断
s
else:
print('输入错误,请重新输入,么么哒') if __name__ == '__main__':
message = {'湖南':
{'衡阳': {'珠珠': '大大学院'},
'湘潭': {'晖晖': '啦啦'}
},
'北京':
{'朝阳':
{'晖晖': '啦啦'}
}
}
menu(message)

  

plus -> 经历社会毒打
  想函数编程未实现,现在看不懂系列,try...except...?什么鬼?

def menu_to(message):
'''打印菜单'''
try:
message.endswith('end')
except:
for i in message:
print(i)
else:
print(message.replace('end', '')) def get_message_key(message_info):
'''获得每层字典的单边值'''
try:
keys = []
for i in message_info:
message_info[i]
keys.append(i)
return keys
except:
return message_info + 'end' def menu_go(message_info):
'''进入主菜单'''
while True:
try:
judgment(message_info)
except Exception as e:
print(e) def judgment(message_info):
'''循环菜单'''
keys = get_message_key(message_info)
while True:
menu_to(keys) choice = input('请输入>>>:')
if choice == ec:
print('暂时未实现')
return judgment(message_info)
elif choice == ex:
exit('退出程序') if type(keys) == type('str') and keys.endswith('end'):
print('菜单到底了')
continue
else: if choice in keys:
message_info = message_info[choice]
return judgment(message_info)
else:
print('输入错误,请重新输入') if __name__ == '__main__':
message = {'湖南':
{'衡阳': {'珠珠': '大大学院'},
'湘潭': {'晖晖': '啦啦'}
},
'北京':
{'朝阳':
{'晖晖': '啦啦'}
}
} ec = 'q' # 返回上一级
ex = 'e' # 退出程序
menu_go(message)

  

  核心思路
    1. 创建三个状态变量,一个保存当前菜单状态,一个保存当前菜单路径,一个保存初始状态
    2. 进入菜单,检查输入的菜单是否存在,不存在则重新输入,再检查是否能进入下一层,不能进入菜单,状态不更新
    3. 进入菜单,存在和进入下一层检查通过,添加菜单到路径,进入下一层,更新当前菜单状态到下一层菜单状态
    4. 返回上一层,则从菜单路径删除尾部,从初始状态按路径查找,然后更新当前菜单状态

__author__ = 'beimenchuixue'
__blog__ = 'http://www.cnblogs.com/2bjiujiu/' class Menu(object):
"""三级菜单类 核心思路
1. 创建三个状态变量,一个保存当前菜单状态,一个保存当前菜单路径,一个保存初始状态
2. 进入菜单,检查输入的菜单是否存在,不存在则重新输入,再检查是否能进入下一层,不能进入菜单,状态不更新
3. 进入菜单,存在和进入下一层检查通过,添加菜单到路径,进入下一层,更新当前菜单状态到下一层菜单状态
4. 返回上一层,则从菜单路径删除尾部,从初始状态按路径查找,然后更新当前菜单状态
""" def __init__(self, msg):
# __current_menu 是个当前临时菜单状态, msg保存最初状态
self.__current_menu = self.msg = msg
# 菜单路径,因为菜单路径是唯一且互斥的
self.path = [] def user_input(self):
"""获取用户的输入"""
prompt = "{}请输入>>>:".format(len(self.path)+1)
menu = input(prompt).strip()
return menu def run(self):
"""主菜单"""
# 打印提示
self.prompt() while True:
# 打印当前菜单
menu_keys = self.__current_menu.keys()
self.output_prompt(menu_keys) # 获取用户输入
menu = self.user_input()
if not menu:
continue # 退出程序
if menu == "e":
self.exit_prompt()
break # 返回上一级
elif menu == "q":
# 如果到最顶级,后面就没必要执行力
if len(self.path) == 0:
self.top_prompt()
continue
else:
# 菜单往上一级
self.out_menu()
else:
# 进入菜单
self.into_menu(menu)
# 进入菜单
pass def _check_exit(self, menu):
"""检查菜单是否存在"""
keys = self.__current_menu.keys()
# 检查菜单是否存在
if menu in keys:
return True def _check_next(self, menu):
"""查看是否有下一菜单"""
res = self.__current_menu.get(menu, None)
if type(res) is dict:
return True def into_menu(self, menu):
"""获取路径,并修改路径"""
# 是否到最底层最底部了
is_exit, is_next = self._check_exit(menu), self._check_next(menu)
# 判断菜单是否不存在,不存在返回
if not is_exit:
self.not_exit_prompt()
return # 判断是否菜单到底部, 到底部打印提示返回
if not is_next:
self.bottom_prompt()
return # 把菜单添加到菜单路径
self.path.append(menu)
# 更改当前的菜单状态
self.__current_menu = self.__current_menu.get(menu) def out_menu(self):
"""回退菜单"""
# 回退一个路径
self.path.pop()
# 更新当前菜单
self.update_menu()
pass def update_menu(self):
"""更新当前菜单"""
# 如果有路径,通过路径更新当前菜单状态,没有路径说明到顶级菜单了
if self.path:
for item in self.path:
temp_menu = self.msg.get(item)
self.__current_menu = temp_menu
else:
self.__current_menu = self.msg def prompt(self):
"""打印菜单提示"""
menu_template = "按q返回上一层\n" + "按e退出\n"
print(menu_template, end="")
pass def output_prompt(self, menu_keys):
"""打印菜单"""
print("menu".center(30, "."))
for item in menu_keys:
print(item) def exit_prompt(self):
"""答应退出提示"""
print('退出中……ing')
print(''.center(30, "-"))
pass def top_prompt(self):
"""打印到顶层提示"""
print('已经最顶级菜单 ')
print(''.center(30, "-"))
pass def bottom_prompt(self):
"""打印到顶层提示"""
print('已经最底层级菜单 ')
print(''.center(30, "-"))
pass def not_exit_prompt(self):
"""选择不存在提示"""
print("选择不存在,重新输入")
print(''.center(30, "-"))
pass if __name__ == "__main__":
message = {'湖南':
{'衡阳': {'珠珠': '大大学院'},
'湘潭': {'晖晖': '啦啦'}
},
'北京':
{'朝阳':
{'晖晖': '啦啦'}
}
} menu = Menu(message)
menu.run()

  

pro -> 假装坚强 |^_^|
  核心思路 -> 利用备忘录设计模式实现三级菜单
    1. 创建两个变量,一个是保存各个层级菜单状态,一个是保存当前状态指向索引
    2. 进入菜单,检查输入的菜单是否存在,不存在则重新输入,再检查是否能进入下一层,不能进入菜单,状态不更新
    3. 进入菜单,存在和进入下一层检查通过, 状态索引自增1,当前状态加入备忘录
    4. 返回上一层,状态索引减一

__author__ = 'beimenchuixue'
__blog__ = 'http://www.cnblogs.com/2bjiujiu/' class Menu(object):
"""三级菜单类 核心思路 -> 利用备忘录模式实现三级菜单
1. 创建两个变量,一个是保存各个层级菜单状态,一个是保存当前状态指向索引
""" def __init__(self, msg):
# 初始索引状态
self.__index = 0 # 备忘录(memo)状态
self.__memo = {self.__index: msg} def user_input(self):
"""获取用户的输入"""
prompt = "{}请输入>>>:".format(len(self.path) + 1)
menu = input(prompt).strip()
return menu def run(self):
"""主菜单"""
# 打印提示
self.prompt() while True:
# 打印当前菜单
menu_keys = self.__current_menu.get(self.__index).keys()
self.output_prompt(menu_keys) # 获取用户输入
menu = self.user_input()
if not menu:
continue # 退出程序
if menu == "e":
self.exit_prompt()
break # 返回上一级
elif menu == "q":
# 如果到最顶级,后面就没必要执行力
if self.__index == 0:
self.top_prompt()
continue
else:
# 菜单往上一级
self.out_menu()
else:
# 进入菜单
self.into_menu(menu)
# 进入菜单
pass def __current_status(self):
return self.__memo.get(self.__index) def _check_exit(self, menu):
"""检查菜单是否存在"""
keys = self.__current_status().keys()
# 检查菜单是否存在
if menu in keys:
return True def _check_next(self, menu):
"""查看是否有下一菜单"""
res = self.__current_status().get(menu, None)
if type(res) is dict:
return True def into_menu(self, menu):
"""获取路径,并修改路径"""
# 是否到最底层最底部了
is_exit, is_next = self._check_exit(menu), self._check_next(menu)
# 判断菜单是否不存在,不存在返回
if not is_exit:
self.not_exit_prompt()
return # 判断是否菜单到底部, 到底部打印提示返回
if not is_next:
self.bottom_prompt()
return # 当前状态
current_status = self.__current_status()
# 把菜单添加到菜单路径
self.__index += 1
# 把当前状态加进备忘录
self.__memo[self.__index] = current_status def out_menu(self):
"""回退菜单"""
# 状态索引减一
self.__index -= 1 def prompt(self):
"""打印菜单提示"""
menu_template = "按q返回上一层\n" + "按e退出\n"
print(menu_template)
pass def output_prompt(self, menu_keys):
"""打印菜单"""
print("menu".center(30, "."))
for item in menu_keys:
print(item) def exit_prompt(self):
"""答应退出提示"""
print('退出中……ing')
print(''.center(30, "-"))
pass def top_prompt(self):
"""打印到顶层提示"""
print('已经最顶级菜单 ')
print(''.center(30, "-"))
pass def bottom_prompt(self):
"""打印到顶层提示"""
print('已经最底层级菜单 ')
print(''.center(30, "-"))
pass def not_exit_prompt(self):
"""选择不存在提示"""
print("选择不存在,重新输入")
print(''.center(30, "-"))
pass if __name__ == "__main__":
message = {'湖南':
{'衡阳': {'珠珠': '大大学院'},
'湘潭': {'晖晖': '啦啦'}
},
'北京':
{'朝阳':
{'晖晖': '啦啦'}
}
} menu = Menu(message)
menu.run()

 走向人生巅峰,迎娶那啥啥啥

三级菜单打怪升级,young -> plus -> pro的更多相关文章

  1. python打怪之路【第三篇】:利用Python实现三级菜单

    程序: 利用Python实现三级菜单 要求: 打印省.市.县三级菜单 可返回上一级 可随时退出程序 coding: menu = { '北京':{ '朝阳':{ '国贸':{ 'CICC':{}, ' ...

  2. python 购物车和三级菜单

    程序:购物车程序 需求: 启动程序后,让用户输入工资,然后打印商品列表 允许用户根据商品编号购买商品 用户选择商品后,检测余额是否够,够就直接扣款,不够就提醒 可随时退出,退出时,打印已购买商品和余额 ...

  3. python 实现三级菜单

    要求: 可选择进入各级子菜单 在各级菜单下可以选择退出 在子菜单下可以返回上一级菜单 Readme: 运行程序,输入菜单选项,进入对应的子菜单 # Joe Young data = { '山东':{ ...

  4. 三级菜单的实现(python程序)

    这是刚开始写程序,三级菜单的程序基本是用字典实现,很low,以后学习了其他更好的东西,我会继续上传,然后争取在我水平高深之后,把这个简单的东西实现的狠高大上. _author_ = "zha ...

  5. 手摸手,带你用vue实现后台管理权限系统及顶栏三级菜单显示

    手摸手,带你用vue实现后台管理权限系统及顶栏三级菜单显示 效果演示地址 项目demo展示 重要功能总结 权限功能的实现 权限路由思路: 根据用户登录的roles信息与路由中配置的roles信息进行比 ...

  6. 运维工程师打怪升级进阶之路 V2.0

    在此之前,发布过两个版本: 运维工程师打怪升级之路 V1.0 版本发布 运维工程师打怪升级必经之路 V1.0.1 很多读者伙伴们反应总结的很系统.很全面,无论是0基础初学者,还是有基础的入门者,或者是 ...

  7. python学习笔记(字符串操作、字典操作、三级菜单实例)

    字符串操作 name = "alex" print(name.capitalize()) #首字母大写 name = "my name is alex" pri ...

  8. css三级菜单效果

    一个简单实用的css三级菜单效果 <!doctype html> <html> <head> <meta charset="utf-8"& ...

  9. python成长之路-----day1-----作业(登录程序和三级菜单)

    作业: 作业1:用户登录 1)程序说明: a.用户输入密码验证成功然后打印欢迎信息 b.如果密码错误,用户登录失败,提示用户,密码错误 c.用户输入密码错误3次,则用户锁定 d.当用户多次输入不存在的 ...

随机推荐

  1. Python Selenium 之数据驱动测试的实现

    数据驱动模式的测试好处相比普通模式的测试就显而易见了吧!使用数据驱动的模式,可以根据业务分解测试数据,只需定义变量,使用外部或者自定义的数据使其参数化,从而避免了使用之前测试脚本中固定的数据.可以将测 ...

  2. Spring Boot 通过CORS实现跨域

    同源策略 很多人对跨域有一种误解,以为这是前端的事,和后端没关系,其实不是这样的,说到跨域,就不得不说说浏览器的同源策略. 同源策略是由 Netscape 提出的一个著名的安全策略,它是浏览器最核心也 ...

  3. 攻防世界——Misc新手练习区解题总结<3>(9-10题)

    第九题SimpleRAR: 下载附件后得到一个压缩包打开后得到如下提示 文件头损坏,让我们打开winhex看一下 7a为子块而文件头为74,这里将7a改为74(这里我也不是很清楚,详细大家可以自行去查 ...

  4. Fitness - 07.23 - Congratulation!

    倒计时161天 运动54分钟,共计5组半,5.8公里.拉伸5分钟. 每组跑步10分钟(6.5KM/h),走路1分钟(5.5KM/h). 终于突破了耐力跑的一天,可喜可贺! 差一点就到6公里了,觉得自己 ...

  5. wpf之DataGrid绑定DataTable,其中DataGridComboBoxColumn双向绑定枚举enum

    百度了快一天,没结果,除了几个原创的,都是复制粘贴的内容. 不想用别的笨办法,于是脑洞大开,想出了我的办法. 首先是前台代码,与网上的比较类似: xmlns:jz="clr-namespac ...

  6. 05 element.ui 全局配置

    element.ui css样式在组件里面改有的不会生效,是因为加了scoped.局部作用,放在这里是全局配置  

  7. 实操ES6之Promise

    箭头函数和this 写Promise的时候,自然而然会使用箭头函数的编写方式.箭头函数就是.Neter们熟知的lambda函数,已经被大部分主流语言支持,也受到了广大码农的交口称赞,但是Jser们却会 ...

  8. 小程序开发-基础组件icon/text/progress入门

    小程序的基础组件--基础内容 基础内容分为三大组件: 1. icon--图标 index.wxml <view class="group"> <block wx: ...

  9. C#开发PACS医学影像处理系统(一):开发背景和说明

    本系列文章将从以下模块和大家分享和讨论使用C#开发医学软件PACS和RIS系统, 国内相关资料比较少,也借此机会丰富一下医学软件开发生态,讨论技术难点,希望大家互相帮助共同进步. 章节介绍及截图预览: ...

  10. 借助FreeHttp任意篡改Websocket报文(Websocket改包)

    前言 作为Web应用中最常见的数据传输协议之一的Websocket,在我们日常工作中也势必会经常使用到,而在调试或测试中我们常常也有直接改变Websocket数据报文以确认其对应用的影响的需求,本文将 ...