django 数据库返回queryset实现封装为字典
更新时间:2020年05月19日 08:45:33 作者:timxie_letour
这篇文章主要介绍了django 数据库返回queryset实现封装为字典,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
默认情况下,Python DB API会返回不带字段的结果,这意味着你得到的是一个列表,而不是一个字典。花费一点性能代价之后,你可以返回一个字典形式的结果,像这样:
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.字段}
生成列表了
补充知识:[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)
以上这篇django 数据库返回queryset实现封装为字典就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
教你如何将 Sublime 3 打造成 Python/Django IDE开发利器
Sublime Text 是一款非常强大的文本编辑器, 下面我们介绍如何将 Sublime Text 3 打造成一款 Python/Django 开发利器:2014-07-07jupyter notebook 调用环境中的Keras或者pytorch教程
这篇文章主要介绍了jupyter notebook 调用环境中的Keras或者pytorch教程,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2020-04-04Python使用progressbar模块实现的显示进度条功能
这篇文章主要介绍了Python使用progressbar模块实现的显示进度条功能,简单介绍了progressbar模块的安装,并结合实例形式分析了Python使用progressbar模块显示进度条的相关操作技巧,需要的朋友可以参考下2018-05-05
最新评论