您好,登錄后才能下訂單哦!
這篇文章主要講解了django數(shù)據(jù)庫返回queryset實現(xiàn)封裝為字典的方式,內(nèi)容清晰明了,對此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會有幫助。
默認(rèn)情況下,Python DB API會返回不帶字段的結(jié)果,這意味著你得到的是一個列表,而不是一個字典?;ㄙM一點性能代價之后,你可以返回一個字典形式的結(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
這樣在前臺,就可以通過
{%for i in dic%}
{i.字段}
生成列表了
補(bǔ)充知識:[django] queryset系列化3種方式model_to_dict、serializers
我就廢話不多說了,大家還是直接看代碼吧!
# 序列化方式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)
看完上述內(nèi)容,是不是對django數(shù)據(jù)庫返回queryset實現(xiàn)封裝為字典的方式有進(jìn)一步的了解,如果還想學(xué)習(xí)更多內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。