djangoデータベースがquerysetに戻り、辞書としてパッケージ化されます。
デフォルトでは、Python DB APIはフィールドなしの結果を返します。これは辞書ではなくリストを得ることを意味します。少しの性能の代償を払ったら、辞書形式の結果を返してもいいです。
「%for i in dic%」
{i.フィールド}
リストを生成しました
追加知識:[django]querysetシリーズ化3つの方式model_to_dict、serializers
余計なことを言わないで、コードを見てください。
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()
]
デモ:
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に戻りました。辞書としてパッケージ化されたことを実現しました。皆さんへのすべての内容を共有しています。