python-三级菜单的优化实现
三级菜单需求:
1.可依次选择进入各子菜单
2.可从任意一层往回退到上一层
3.可从任意一层退出程序
所需新知识点:列表、字典
先通过字典建立数据结构
#创建字典
city_dic = {
"北京":{
"海淀区": {
"人大附中":{
"足球":{},
"篮球":{},
"排球":{},
}, "十一学校":{
"足球":{},
"篮球":{},
"排球":{},
},
"育英学校":{
"足球":{},
"篮球":{},
"排球":{},
},
},
"西城区":{
"北师大附中":{
"足球":{},
"篮球":{},
"排球":{},
},
"三十五中":{
"足球":{},
"篮球":{},
"排球":{},
},
"八中":{
"足球":{},
"篮球":{},
"排球":{},
}, },
"东城区":{
"四中":{
"足球":{},
"篮球":{},
"排球":{},
},
"二中":{
"足球":{},
"篮球":{},
"排球":{},
},
"一中":{
"足球":{},
"篮球":{},
"排球":{},
},
},
"朝阳区":{
"民大附中":{
"足球":{},
"篮球":{},
"排球":{},
},
"7中":{
"足球":{},
"篮球":{},
"排球":{},
},
"9中":{
"足球":{},
"篮球":{},
"排球":{},
}, },
},
"上海":{
"黄埔区":{
"3中":{
"足球":{},
"篮球":{},
"排球":{},
},
"4中": {
"足球":{},
"篮球":{},
"排球":{},
},
"5中": {
"足球":{},
"篮球":{},
"排球":{},
},
},
"徐汇区":{
"6中": {
"足球":{},
"篮球":{},
"排球":{},
},
"7中": {
"足球":{},
"篮球":{},
"排球":{},
},
"8中": {
"足球":{},
"篮球":{},
"排球":{},
},
},
"长宁区":{
"9中": {
"足球":{},
"篮球":{},
"排球":{},
},
"10中": {
"足球":{},
"篮球":{},
"排球":{},
},
"11中": {
"足球":{},
"篮球":{},
"排球":{},
},
},
},
"黑龙江":{
"哈尔滨":{
"1中": {
"足球":{},
"篮球":{},
"排球":{},
},
"2中":{
"足球":{},
"篮球":{},
"排球":{},
},
"3中": {
"足球":{},
"篮球":{},
"排球":{},
},
},
"大庆":{
"4中":{
"足球":{},
"篮球":{},
"排球":{},
},
"5中": {
"足球":{},
"篮球":{},
"排球":{},
},
"6中": {
"足球":{},
"篮球":{},
"排球":{},
},
},
"牡丹江":{
"7中":{
"足球":{},
"篮球":{},
"排球":{},
},
"8中": {
"足球":{},
"篮球":{},
"排球":{},
},
"9中": {
"足球":{},
"篮球":{},
"排球":{},
},
},
"佳木斯":{
"10中": {
"足球":{},
"篮球":{},
"排球":{},
},
"11中": {
"足球":{},
"篮球":{},
"排球":{},
},
"12中": {
"足球":{},
"篮球":{},
"排球":{},
},
},
},
}
优化版实现代码:15行
current_layer = city_dic #当前层
last_layers = [city_dic] #把当前层赋值给列表,方便退出时使用
while True:
#循环打印字典列表key
for key in current_layer:
print(key)
choice = input(">>>:").strip() #等待用户输入
if choice == "": continue #判断是否为空,为空则continue,
if choice in current_layer: #进入下一层
last_layers.append(current_layer) #把当前层添加到列表
current_layer = current_layer[choice] #当前层变为选择choice的下一层
if choice == "b":
if last_layers:
current_layer = last_layers[-1] #从列表中取到最后一个值,即循环的上一层,赋值给current_layer
last_layers.pop() #取完列表中最后一个值后,要把它从列表中删除,pop()默认删除列表中最后一个,也可以写成pop(-1)
if choice == "q": break # 如果输入q,结束程序。
python-三级菜单的优化实现的更多相关文章
- Python 三级菜单与优化(一层循环嵌套)
优化的思路是使用单层循环嵌套完成三级菜单,这个优化思路我非常喜欢,我喜欢在编程的时候用最少的东西写出同样的效果,通常这样会绕来绕去,但非常有趣!!! 需求: 1.运行程序输出第一级菜单: 2.选择一级 ...
- python(5)- 简单练习:python三级菜单优化
python三级菜单优化,菜鸟版链接:http://www.cnblogs.com/xuyaping/p/6648170.html menu = { '北京':{ '海淀':{ '五道口':{ 'so ...
- python三级菜单实例(傻瓜版和进阶版)
程序: python三级菜单 要求: : 1.打印省.市.县三级菜单 2.可返回上一级 3.可随时退出程序 方案一:傻瓜版(其实傻瓜版考察的主要是思路!思路清楚了,那才不是傻瓜!O(∩_∩)O哈哈~) ...
- python三级菜单的实现
一.作业要求 1.使用字典实现三级菜单功能 2.直接输入前面数字进入下一级菜单 3.按B返回上一级,按Q退出 二.需要知识点 1.if循环 2.for循环,enumerate的用法 3.while循环 ...
- python 三级菜单 while循环三次,湖北省市-县-街道的选择,3个while的循环 -day2
python编写一个三级while的循环菜单 1.定义字典,字典里面嵌套字典,内嵌字典的值为列表. 思路: 湖北省的市:字典中的定义3个字典,用于存储{序列-键:市名} shiqu_dir = {} ...
- Python 三级菜单 增强版
需要实现的功能是:三级菜单1.从文本内读出选项2.查询每一级的选项,并能对选项进行增/删/改功能3.每一级可以退出程序或者返回上一层 2018-5-14 更新内容 思路 实现过程中的BUG及解决方案: ...
- python三级菜单
#-*- coding:utf-8 -*-#Author:gxli #一级菜单项def menu(): #遍历字典dic一级菜单 print('-----------一级菜单------------- ...
- Python——三级菜单
#三级菜单函数 menu = { '北京':{ 海淀:{ '五道口':{} '中关村':{} '上帝':{} } '昌平':{} '朝阳':{} '东城':{} }, '上海':{} '山东':{} ...
- 4th,Python三级菜单
1. 运行程序输出第一级菜单 2. 选择一级菜单某项,输出二级菜单,同理输出三级菜单 3. 菜单数据保存在文件中 4. 让用户选择是否要退出 5. 有返回上一级菜单的功能 data = { '北京': ...
- [terry笔记]python三级菜单
把三级菜单输出,选择后逐层显示,”b“返回上一级菜单. menu = { '北京':{ '海淀':{ '五道口':{ 'soho':{}, '网易':{}, 'google':{} }, '中关村': ...
随机推荐
- AJAX 学习笔记 2017_05_04
1.使用 AJAX 修改该文本内容 <%@ page language="java" contentType="text/html; charset=UTF-8&q ...
- 关于Cookie 的HttpOnly属性(java/web操作cookie+Tomcat操作jsessionid)
关于Cookie的其它只是不在累述.本文主要讲讲自己在项目中遇到的cookie的HttpOnly属性问题 Cookie的HttpOnly属性说明 cookie的两个新的属性secure和Httponl ...
- 3元购买微信小程序解决方案一个月
一.登录微信公众平台https://mp.weixin.qq.com/ 二.点击立即注册.注意:这里不要用微信公众号登录,小程序账号和微信公众号是不同的. 三.在注册页面点击小程序板块. 四.进入小程 ...
- Oracle Dataguard 基本原理
转载-http://blog.sina.com.cn/s/blog_7c5a82970101prcx.html 1.DATAGUARD原理 DATAGUARD是通过建立一个PRIMARY和STANDB ...
- 1.GlusterFS 初识
一. GlusterFS 初始 1.1 分布式文件系统出现 计算机通过文件系统管理.存储数据,而现在数据信息爆炸的时代中人们可以获取的数据成指数倍的增长,单纯通过增加硬盘个数来扩展计算机文件系统的存储 ...
- Wannafly模拟赛
题目描述 给出一个n * m的矩阵.让你从中发现一个最大的正方形.使得这样子的正方形在矩阵中出现了至少两次.输出最大正方形的边长. 输入描述: 第一行两个整数n, m代表矩阵的长和宽: 接下来n行,每 ...
- luogu P1768 天路
嘟嘟嘟 01分数规划之最优比率环. 主要是发一下基于dfs的spfa.跑的贼快,原来总用时2000多ms还TLE了两个点,改成dfs后总用时直降43ms! #include<cstdio> ...
- nodejs protobuff node-protobuf c++ windows扩展安装笔记
https://www.npmjs.com/package/node-protobuf 按照作者所说的办法在windows平台安装的办法,先到google的github下载2.6.1版本的protob ...
- c#用链表存储并读取配置文件(代码部分)
//读取配置参数 private void loadcofig() { //List<param> camra1 = new List<param>(); List<st ...
- jdbc连接各种数据库字符串
oracle driverClass:oracle.jdbc.driver.OracleDriver url:jdbc:oracle:thin:@127.0.0.1:1521:dbname mysql ...