django 数据库返回queryset实现封装为字典
默认情况下,PythonDBAPI会返回不带字段的结果,这意味着你得到的是一个列表,而不是一个字典。花费一点性能代价之后,你可以返回一个字典形式的结果,像这样:
defdictfetchall(cursor): "Returnsallrowsfromacursorasadict" desc=cursor.description return[ dict(zip([col[0]forcolindesc],row)) forrowincursor.fetchall() ]
demo:
fromdjango.dbimportconnection
if__name__=='__main__':
"""db=db_operate()
sql='selectDISTINCTt1.HostName,t2.IpAddress,t2.RegName,t2.AppUser,t2.`Desc`frommachineinfoast1,asset_appregioninfoast2wheret1.IpAddress=t2.IpAddress;'
result=db.mysql_command(settings.conn,sql)
dic=dict(result)
printdic
"""
cur=connection.cursor()
cur.execute('selectDISTINCTt1.HostName,t2.IpAddress,t2.RegName,t2.AppUser,t2.`Desc`frommachineinfoast1,asset_appregioninfoast2wheret1.IpAddress=t2.IpAddress;')
dic=dictfetchall(cur)
printdic
这样在前台,就可以通过
{%foriindic%}
{i.字段}
生成列表了
补充知识:[django]queryset系列化3种方式model_to_dict、serializers
我就废话不多说了,大家还是直接看代码吧!
#序列化方式1:
fromdjango.forms.modelsimportmodel_to_dict
importjson
data=[]
forobjinbook_list:
data.append(model_to_dict(obj))
print(data)
returnHttpResponse("ok")
#序列化方式2:
data=serializers.serialize("json",book_list)
returnHttpResponse(data)
#序列化方式3:
bs=BookSerializers(book_list,many=True)
returnResponse(bs.data)
以上这篇django数据库返回queryset实现封装为字典就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。