这篇文章主要讲解了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实现封装为字典的方式有进一步的了解,如果还想学习更多内容,欢迎关注亿速云行业资讯频道。
亿速云「云数据库 MySQL」免部署即开即用,比自行安装部署数据库高出1倍以上的性能,双节点冗余防止单节点故障,数据自动定期备份随时恢复。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。