三级菜单:
1. 运行程序输出第一级菜单
2. 选择一级菜单某项,输出二级菜单,同理输出三级菜单
3. 菜单数据保存在文件中
4. 让用户选择是否要退出
5. 有返回上一级菜单的功能
类定义:menu_class.py
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# author : Wang Yue
#menu class
#定义菜单类,属性使用的实例属性,没有使用类属性,类属性共享给全部实例,会有问题的,这是百度才知道。
class menu_level(object):
def __init__(self,real_name,real_my_id,real_parent_id):
self.name=real_name #菜单名称
self.my_id=real_my_id #菜单id
self.parent_menu_id=real_parent_id #上级菜单id
self.child_menu=[] #子菜单实例集合
self.here = False # means hold one 用户所在位置
#以下是一系列的属性操作方法
def put_name(self,real_name):
self.name=real_name
def get_name(self):
return self.name
def put_my_id(self,real_my_id):
self.my_id=real_my_id
def get_my_id(self):
return self.my_id
def put_par_id(self,real_par_id):
self.parent_menu_id=real_par_id
def get_par_id(self):
return self.parent_menu_id
def put_here_true(self):
self.here=True
def put_here_false(self):
self.here=False
def get_here(self):
return self.here
def get_child(self):
return self.child_menu
def set_child(self,child):
self.child_menu=child
def append_child(self,menu_child):
self.child_menu.append(menu_child)
入口程序:
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# author : Wang Yue
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# author : Wang Yue
#主函数:进行各种业务的入口
#导入具体各个方法逻辑的文件,和sys库
import menu_fuc,sys
#运行时,需要知道运行方式。
if __name__ == "__main__":
menu=menu_fuc.init_menu() #类初始化实例
p_menu=menu_fuc.init_child(menu,0) #整理菜单,0为根,弄成一个菜单列表,有层级的,列表中的元素是最上的根。
print(">>{_name}".format(_name=p_menu[0].get_name())) #按照需求,运行程序就打印根路径名称
while True:
#用循环维持整体操作环境
#提供以下命令:
#1、view,显示当前所在位置的路径,就是面包屑
#2、next 菜单名称,到相应的菜单去
#3、back,返回上一级菜单
#4、tree,列出完整的菜单树
#5、quit,退出程序
# cmd is "view |next #name|back|tree|quit" view:where am i | next #name:where are you go | back:back to sup menu| tree list all menu|quit is exit
cmd=input("MENU CMD:")
if cmd =="view":
name_que=menu_fuc.view_menu(menu) #列出当前所在完整路径,面包屑
last_name=name_que[-2]
for name in name_que:
print("{_name}".format(_name=name),end=">>>")
if name==last_name:
print(name_que[-1])
break
elif "next" in cmd:
cmd_go=cmd.split() #进入某一级菜单,根据菜单名称,不仅仅是下级。随意切换
name=cmd_go[1]
menu_fuc.next_menus(name,menu) #按照需求,当进入某一级后,要列出下级所有菜单名称
menu_fuc.next_menu(menu,name) #进入下级的执行代码的方法函数
elif cmd=="back":
menu_fuc.back_menu(menu) #返回上级的方法函数
elif cmd == "tree":
menu_fuc.tree_menu(p_menu,">>") #列出完整菜单树的方法函数
elif cmd == "quit" :
sys.exit(0)
else:
cmd_help='''
my menu CMD:
view:where am i(view Current path)
next #name:where are you go (go to #name menu)
back:back to parent menu
tree:list all tree
quit:exit menu
提供以下命令:
1、view,显示当前所在位置的路径,就是面包屑
2、next 菜单名称,到相应的菜单去
3、back,返回上一级菜单
4、tree,列出完整的菜单树
5、quit,退出程序
'''
print(cmd_help)
业务程序处理:
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# author : Wang Yue
import menu_class,re
#初始化用户菜单的各个实例
def init_menu():
menu_list=[]
with open("menu_db.doo",mode="r",encoding="utf-8") as menu_db:
menu_db.flush()
menu_db.seek(0)
lines=menu_db.readlines()
for line_m in lines:
line_f=line_m.strip()
line=re.split(',',line_f)
menu_cl=menu_class.menu_level(line[1],int(line[0]),int(line[2]))
menu_list.append(menu_cl)
return menu_list
#将子节点集合存入相应的父菜单实例的child列表中
def init_child(menu_list,pid):
p_menu=[]
for menu_one in menu_list:
# print("my id is:{_name}".format(_name=menu_one.get_my_id()))
if menu_one.get_par_id() == pid:
p_menu.append(menu_one)
for ppp in p_menu:
get_sub_node(menu_list,ppp)
return p_menu
def get_sub_node(menu_list,p_node): #上一个方法中,会调用此方法,寻找下级的子节点,利用递归一层一层查找
for menu_child in menu_list:
if p_node.get_my_id() == menu_child.get_par_id():
# print(menu_child.get_name())
p_node.append_child(menu_child)
get_sub_node(menu_list,menu_child)
def get_back_menu(menu,menu_here,menu_que): #返回上级路径的方法
for menu_one in menu:
if menu_here.get_par_id() == menu_one.get_my_id():
menu_que.append(menu_one)
if menu_one.get_par_id() != 0:
get_back_menu(menu,menu_one,menu_que)
return menu_que
def view_menu(menu): #查看当前所在路径。
menu_name_que=[]
temp_que=[]
menu_que=[]
for menu_one in menu:
if menu_one.get_here():#find which menu
menu_que=get_back_menu(menu,menu_one,temp_que)
menu_que.insert(0,menu_one)
break
menu_que.reverse()
for my_menu in menu_que:
menu_name_que.append(my_menu.get_name())
return menu_name_que
def next_menu(menu,name): #进入下一级路径。
for menu_one in menu:
if menu_one.get_name()==name:
menu_one.put_here_true()
menu_next=menu_one
elif menu_one.get_here():
menu_one.put_here_false()
def back_menu(menu): #返回上级菜单
for menu_one in menu:
if menu_one.get_here():
menu_one.put_here_false()
for menu_two in menu:
if menu_two.get_my_id() == menu_one.get_par_id():
menu_two.put_here_true();
def tree_menu(menu,logo): #显示完整菜单树,也是递归方法
m=logo
# root = tree_assembly(menu, p_id)
for menu_root in menu:
print(m+menu_root.get_name())
if len(menu_root.get_child()) > 0:
tree_menu(menu_root.get_child(),logo+m)
def next_menus(now_menu_name,menu): #在进入下级菜单时,显示下级全部菜单。
for which_menu in menu:
if which_menu.get_name() == now_menu_name:
now_menu=which_menu
ne_menu = now_menu.get_child()
for ne_one in ne_menu:
print(">>>{_name}".format(_name=ne_one.get_name()))
附:数据文件:
1,中国,0
2,河北,1
3,安徽,1
4,黑龙江,1
5,辽宁,1
6,山东,1
7,内蒙古,1
8,石家庄,2
9,济南,6
10,青岛,6
11,呼伦贝尔,7
12,锡林郭勒,7
13,二连浩特,7
14,海加尔,7
15,承德,2
16,合肥,3
17,哈尔滨,4
18,吉林,5
19,长春,5
20,临沂,6