本篇文章主要介紹了python遞歸查詢選單並轉換成json實例,具有一定的參考價值,有興趣的小夥伴們可以參考一下。
最近需要用python寫一個選單,折騰了兩三天才搞定,現在記錄在此,需要的朋友可以藉鏡一下。
備註:文章引用非可執行完整程式碼,僅僅摘錄了關鍵部分的程式碼
f環境
資料庫: mysql
python:3.6
#表格結構##
CREATE TABLE `tb_menu` ( `id` varchar(32) NOT NULL COMMENT '唯一标识', `menu_name` varchar(40) DEFAULT NULL COMMENT '菜单名称', `menu_url` varchar(100) DEFAULT NULL COMMENT '菜单链接', `type` varchar(1) DEFAULT NULL COMMENT '类型', `parent` varchar(32) DEFAULT NULL COMMENT '父级目录id', `del_flag` varchar(1) NOT NULL DEFAULT '0' COMMENT '删除标志 0:不删除 1:已删除', `create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', `update_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间', PRIMARY KEY (`id`) USING BTREE ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='菜单表';
Python程式碼
Menu物件中,有一個子選單列表的引用“subMenus”,類型為list#核心程式碼
def set_subMenus(id, menus): """ 根据传递过来的父菜单id,递归设置各层次父菜单的子菜单列表 :param id: 父级id :param menus: 子菜单列表 :return: 如果这个菜单没有子菜单,返回None;如果有子菜单,返回子菜单列表 """ # 记录子菜单列表 subMenus = [] # 遍历子菜单 for m in menus: if m.parent == id: subMenus.append(m) # 把子菜单的子菜单再循环一遍 for sub in subMenus: menus2 = queryByParent(sub.id) # 还有子菜单 if len(menus): sub.subMenus = set_subMenus(sub.id, menus2) # 子菜单列表不为空 if len(subMenus): return subMenus else: # 没有子菜单了 return None
測試方法
def test_set_subMenus(self): # 一级菜单 rootMenus = queryByParent('') for menu in rootMenus: subMenus = queryByParent(menu.id) menu.subMenus = set_subMenus(menu.id, subMenus)備註:基本流程是:先查詢一級選單,然後分別把該層級選單的id、和這層級選單的子選單列表傳入set_subMenus方法,遞歸進行子選單列表的下級選單設定;
我採用的ORM框架是:sqlalchemy,直接從資料庫查詢出來的Menu對象,轉Json時會報錯。需要重新定義一個DTO類,來把Menu物件轉換成Dto物件。
MenuDtoclass MenuDto():
def init(self, id, menu_name, menu_url, type, parent, subMenus):
super().init()
self.id = id
self.menu_name = menu_name
self.menu_url = menu_url
self.type = type
self.parent = parent
self.subMenus = subMenus
def str(self):
return '%s(id=%s,menu_name=%s,menu_url=%s,type=%s,parent=%s)' % (
self.class.name, self.id, self.menu_name, self.menu_url, self.type, self.parent)
repr = str
於是,重新定義了遞歸設定子選單的方法
def set_subMenuDtos(id, menuDtos): """ 根据传递过来的父菜单id,递归设置各层次父菜单的子菜单列表 :param id: 父级id :param menuDtos: 子菜单列表 :return: 如果这个菜单没有子菜单,返回None;如果有子菜单,返回子菜单列表 """ # 记录子菜单列表 subMenuDtos = [] # 遍历子菜单 for m in menuDtos: m.name = to_pinyin(m.menu_name) if m.parent == id: subMenuDtos.append(m) # 把子菜单的子菜单再循环一遍 for sub in subMenuDtos: menus2 = queryByParent(sub.id) menusDto2 = model_list_2_dto_list(menus2, "MenuDto(id='', menu_name='', menu_url='', type='', parent='', subMenus='')") # 还有子菜单 if len(menuDtos): if len(menusDto2): sub.subMenus = set_subMenuDtos(sub.id, menusDto2) else: # 没有子菜单,删除该节点 sub.delattr('subMenus') # 子菜单列表不为空 if len(subMenuDtos): return subMenuDtos else: # 没有子菜单了 return None
備註:
- #當一個選單沒有子選單時,刪除掉「subMenus」屬性,否則轉Json時會出現空值
- model_list_2_dto_list 方法可以把Menu清單轉成MenuDto清單
- to_pinyin 是把漢字轉成拼音的方法,在這裡不用關注
# def get(self):
param = request.args
id = param['id']
# 如果id为空,查询的是从根目录开始的各级菜单
rootMenus = queryByParent(id)
rootMenuDtos = model_list_2_dto_list(rootMenus,
"MenuDto(id='', menu_name='', menu_url='', type='', parent='', subMenus='')")
# 设置各级子菜单
for menu in rootMenuDtos:
menu.name = to_pinyin(menu.menu_name)
subMenus = queryByParent(menu.id)
if len(subMenus):
subMenuDtos = model_list_2_dto_list(subMenus,
"MenuDto(id='', menu_name='', menu_url='', type='', parent='', subMenus='')")
menu.subMenus = set_subMenuDtos(menu.id, subMenuDtos)
else:
menu.delattr('subMenus')
menus_json = json.dumps(rootMenuDtos, default=lambda o: o.dict, sort_keys=True, allow_nan=false,
skipkeys=true)
# 需要转字典,否则返回的字符串会带有“\”
menus_dict = json_dict(menus_json)
return fullResponse(menus_dict)
fullResponse
from flask import jsonify
def fullResponse(data='', msg='', code=0):
if msg == '':
return jsonify({'code': code, 'data': data})
elif data == '':
return jsonify({'code': code, 'msg': msg})
else:
return jsonify({'code': code, 'msg': msg, 'data': data})
備註:python中json和字典的意思類似,在最後json回傳給頁時,需要先使用json_dict方法轉成dict型,否則傳回的字串會帶有「\」
以上是python選單遞歸查詢以及將資料進行json轉換的實例的詳細內容。更多資訊請關注PHP中文網其他相關文章!

要在有限的時間內最大化學習Python的效率,可以使用Python的datetime、time和schedule模塊。 1.datetime模塊用於記錄和規劃學習時間。 2.time模塊幫助設置學習和休息時間。 3.schedule模塊自動化安排每週學習任務。

Python在遊戲和GUI開發中表現出色。 1)遊戲開發使用Pygame,提供繪圖、音頻等功能,適合創建2D遊戲。 2)GUI開發可選擇Tkinter或PyQt,Tkinter簡單易用,PyQt功能豐富,適合專業開發。

Python适合数据科学、Web开发和自动化任务,而C 适用于系统编程、游戏开发和嵌入式系统。Python以简洁和强大的生态系统著称,C 则以高性能和底层控制能力闻名。

2小時內可以學會Python的基本編程概念和技能。 1.學習變量和數據類型,2.掌握控制流(條件語句和循環),3.理解函數的定義和使用,4.通過簡單示例和代碼片段快速上手Python編程。

Python在web開發、數據科學、機器學習、自動化和腳本編寫等領域有廣泛應用。 1)在web開發中,Django和Flask框架簡化了開發過程。 2)數據科學和機器學習領域,NumPy、Pandas、Scikit-learn和TensorFlow庫提供了強大支持。 3)自動化和腳本編寫方面,Python適用於自動化測試和系統管理等任務。

兩小時內可以學到Python的基礎知識。 1.學習變量和數據類型,2.掌握控制結構如if語句和循環,3.了解函數的定義和使用。這些將幫助你開始編寫簡單的Python程序。

如何在10小時內教計算機小白編程基礎?如果你只有10個小時來教計算機小白一些編程知識,你會選擇教些什麼�...

使用FiddlerEverywhere進行中間人讀取時如何避免被檢測到當你使用FiddlerEverywhere...


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SublimeText3漢化版
中文版,非常好用

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

Dreamweaver Mac版
視覺化網頁開發工具

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具