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()
 ]
デモ:

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に戻りました。辞書としてパッケージ化されたことを実現しました。皆さんへのすべての内容を共有しています。