首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Python/Django QuerySet to list of dicts?

Python/Django QuerySet to list of dicts?
EN

Stack Overflow用户
提问于 2011-12-04 08:49:44
回答 2查看 4.1K关注 0票数 0

这是我的代码:

代码语言:javascript
复制
obj = Object1.objects.get(pk=1)
other_objs = ob1.other_objs.all()

other_objs是Object1对象上的ManyToManyField。

当我执行这段代码时:

代码语言:javascript
复制
print other_objs[0]

我没有得到一个other_obj (应该是一个字典),我得到了一个基于other_obj类中的__unicode__方法的字符串。

我怎样才能得到other_obj字典而不仅仅是unicode字符串?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-12-04 09:00:50

other_objs[0]将是查询的第一个元素,它将不是dict或字符串,而是django模型对象,你可以访问像other_objs[0].myattr1这样的属性,如果你想要dict,你可以使用objects.values_list请求特定的属性,然后用它们创建一个dict,例如

代码语言:javascript
复制
attrs = ['id', 'attr1']
values = Object1.objects.values_list(attrs)[0]
obj_dict = dict(zip(attrs, values))

或者你可以使用django serialization输出dict或json等,但我认为你只需要一个对象,原始查询就足够了。

票数 4
EN

Stack Overflow用户

发布于 2011-12-04 09:00:57

当您执行.all()时,您将获得与您的Object1对象相关的对象的queryset (将其视为list)。

所以,当你执行other_objs[0]时,你会得到第一个相关的对象。然后,当您打印它时,它会调用它的__unicode__方法来实际打印对象。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8372364

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档