国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術(shù)文章
文章詳情頁

django 數(shù)據(jù)庫返回queryset實(shí)現(xiàn)封裝為字典

瀏覽:5日期:2024-10-05 10:32:19

默認(rèn)情況下,Python DB API會返回不帶字段的結(jié)果,這意味著你得到的是一個列表,而不是一個字典。花費(fèi)一點(diǎn)性能代價之后,你可以返回一個字典形式的結(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 connectionif __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_dictimport jsondata=[]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ù)庫返回queryset實(shí)現(xiàn)封裝為字典就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Django
相關(guān)文章:
主站蜘蛛池模板: 宁海县| 平泉县| 呼图壁县| 隆安县| 罗山县| 蓬安县| 新平| 金昌市| 新田县| 建平县| 高密市| 芮城县| 云梦县| 佛教| 宾阳县| 怀化市| 尼木县| 大厂| 塘沽区| 阿拉善盟| 东阳市| 集安市| 信丰县| 桑植县| 县级市| 阳朔县| 南通市| 青龙| 湖北省| 东阿县| 垫江县| 盐池县| 沾化县| 汝城县| 科技| 同仁县| 台东县| 突泉县| 禹州市| 南城县| 明溪县|