django 數(shù)據(jù)庫(kù)返回queryset實(shí)現(xiàn)封裝為字典
默認(rèn)情況下,Python DB API會(huì)返回不帶字段的結(jié)果,這意味著你得到的是一個(gè)列表,而不是一個(gè)字典?;ㄙM(fèi)一點(diǎn)性能代價(jià)之后,你可以返回一個(gè)字典形式的結(jié)果,像這樣:
def dictfetchall(cursor): "Returns all rows from a cursor as a dict" desc = cursor.description return [ dict(zip([col[0] for col in desc], row)) for row in cursor.fetchall() ]
demo:
from django.db import connection if __name__ == '__main__': """db=db_operate() sql='select DISTINCT t1.HostName,t2.IpAddress,t2.RegName,t2.AppUser,t2.`Desc` from machineinfo as t1,asset_appregioninfo as t2 where t1.IpAddress=t2.IpAddress;' result=db.mysql_command(settings.conn, sql) dic=dict(result) print dic """ cur=connection.cursor() cur.execute('select DISTINCT t1.HostName,t2.IpAddress,t2.RegName,t2.AppUser,t2.`Desc` from machineinfo as t1,asset_appregioninfo as t2 where t1.IpAddress=t2.IpAddress;') dic=dictfetchall(cur) print dic
這樣在前臺(tái),就可以通過(guò)
{%for i in dic%}
{i.字段}
生成列表了
補(bǔ)充知識(shí):[django] queryset系列化3種方式model_to_dict、serializers
我就廢話(huà)不多說(shuō)了,大家還是直接看代碼吧!
# 序列化方式1: from django.forms.models import model_to_dict import json data=[] for obj in book_list: data.append(model_to_dict(obj)) print(data) return HttpResponse("ok") # 序列化方式2: data=serializers.serialize("json",book_list) return HttpResponse(data) # 序列化方式3: bs=BookSerializers(book_list,many=True) return Response(bs.data)
以上這篇django 數(shù)據(jù)庫(kù)返回queryset實(shí)現(xiàn)封裝為字典就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- Django ForeignKey與數(shù)據(jù)庫(kù)的FOREIGN KEY約束詳解
- pycharm中django框架連接mysql數(shù)據(jù)庫(kù)的方法
- django使用多個(gè)數(shù)據(jù)庫(kù)的方法實(shí)例
- django inspectdb 操作已有數(shù)據(jù)庫(kù)數(shù)據(jù)的使用步驟
- Python web框架(django,flask)實(shí)現(xiàn)mysql數(shù)據(jù)庫(kù)讀寫(xiě)分離的示例
- Django連接本地mysql數(shù)據(jù)庫(kù)(pycharm)的步驟
- django 解決model中類(lèi)寫(xiě)不到數(shù)據(jù)庫(kù)中,數(shù)據(jù)庫(kù)無(wú)此字段的問(wèn)題
- Python的Django框架實(shí)現(xiàn)數(shù)據(jù)庫(kù)查詢(xún)(不返回QuerySet的方法)
- Django項(xiàng)目如何給數(shù)據(jù)庫(kù)添加約束
相關(guān)文章
解讀python基于netconf協(xié)議獲取網(wǎng)元的數(shù)據(jù)
大多數(shù)企業(yè)都需要網(wǎng)絡(luò)支撐企業(yè)的ICT運(yùn)行,針對(duì)企業(yè)網(wǎng)絡(luò)中的網(wǎng)元設(shè)備(包括交換機(jī),路由器,防火墻等),很多企業(yè)希望根據(jù)自身的業(yè)務(wù)特點(diǎn)定制網(wǎng)絡(luò)管理,如下就以華為的NE40E網(wǎng)元為例,說(shuō)明如何通過(guò)python基于netconf協(xié)議實(shí)現(xiàn)對(duì)于網(wǎng)元配置數(shù)據(jù)的獲取。2021-05-05教你如何將 Sublime 3 打造成 Python/Django IDE開(kāi)發(fā)利器
Sublime Text 是一款非常強(qiáng)大的文本編輯器, 下面我們介紹如何將 Sublime Text 3 打造成一款 Python/Django 開(kāi)發(fā)利器:2014-07-07jupyter notebook 調(diào)用環(huán)境中的Keras或者pytorch教程
這篇文章主要介紹了jupyter notebook 調(diào)用環(huán)境中的Keras或者pytorch教程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-04-04Python人工智能構(gòu)建簡(jiǎn)單聊天機(jī)器人示例詳解
這篇文章主要為大家介紹了Python人工智能構(gòu)建簡(jiǎn)單聊天機(jī)器人示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-03-03Python使用progressbar模塊實(shí)現(xiàn)的顯示進(jìn)度條功能
這篇文章主要介紹了Python使用progressbar模塊實(shí)現(xiàn)的顯示進(jìn)度條功能,簡(jiǎn)單介紹了progressbar模塊的安裝,并結(jié)合實(shí)例形式分析了Python使用progressbar模塊顯示進(jìn)度條的相關(guān)操作技巧,需要的朋友可以參考下2018-05-05