django 数据库返回queryset实现封装为字典
作者:timxie_letour 时间:2024-01-20 15:43:43
默认情况下,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)
来源:https://blog.csdn.net/timxie_letour/article/details/52115776
标签:django,queryset,封装,字典
0
投稿
猜你喜欢
Python如何自定义邻接表图类
2021-01-12 04:41:43
Python基于列表模拟堆栈和队列功能示例
2021-08-17 01:36:14
PDO::errorCode讲解
2023-06-08 03:39:17
Python 实现自动获取种子磁力链接方式
2022-12-19 16:17:31
使用Python编写类UNIX系统的命令行工具的教程
2023-08-24 05:03:02
python使用多线程+socket实现端口扫描
2023-04-14 19:21:14
Python3利用Dlib19.7实现摄像头人脸识别的方法
2022-08-08 06:41:22
Python3.8安装tensorflow的简单方法步骤
2021-03-11 23:31:42
python连接池实现示例程序
2022-04-30 21:59:54
浅谈Python中文件夹和python package包的区别
2021-03-23 21:57:26
一文掌握Go语言并发编程必备的Mutex互斥锁
2024-05-13 10:43:30
Python字符串的15个基本操作(小结)
2023-08-11 00:11:13
如何基于python对接钉钉并获取access_token
2023-11-27 04:25:07
python的类方法和静态方法
2021-04-14 21:05:22
浅谈pytorch池化maxpool2D注意事项
2023-07-14 15:02:30
Pycharm+Scrapy安装并且初始化项目的方法
2023-03-05 11:49:00
Codeigniter控制器controller继承问题实例分析
2023-11-23 04:15:31
Mysql exists用法小结
2024-01-18 00:51:54
asp源码如何显示数据库字段的结构?
2010-06-08 09:35:00
用PHP实现标准的IP Whois查询
2023-11-14 19:35:01