无法将 Django 查询集转换为列表 [重复]

Posted

技术标签:

【中文标题】无法将 Django 查询集转换为列表 [重复]【英文标题】:Cannot convert Django Queryset to a List [duplicate] 【发布时间】:2020-01-09 06:32:39 【问题描述】:

我创建了以下查询:

my_books = Book.objects.values('title') 
print(my_books)

输出是:

<QuerySet ['title': 'It do go down', 'title': 'Second Post', 'title': 'Tesla - A New Generation']>

现在我想更改 QuerySet 以返回一个应该如下所示的列表:

['It do go down', 'Second Post', 'Tesla - A New Generation']

我必须做什么才能获得上述结果?

PS:我尝试的是一个相关问题的答案:print(list(my_books)),它显示了以下内容:

['title': 'It do go down', 'title': 'Second Post', 'title': 'Tesla - A New Generation']

此外,我尝试了一个迭代,它根本不起作用。

【问题讨论】:

【参考方案1】:

如果你想要一个列表,你应该使用values_list

my_books = Book.objects.values_list('title', flat=True) 

flat=True 参数使其成为平面列表,而不是列表列表。

【讨论】:

以上是关于无法将 Django 查询集转换为列表 [重复]的主要内容,如果未能解决你的问题,请参考以下文章

有没有办法将 Django 模型查询集转换为模板中的 json 或 json 字符串?

无法将 groupby 数据集转换为 pandas 中的 json [重复]

Django查询集获得精确的多对多查询[重复]

如何将列表转换为queryset django

合并或联合动态创建的查询集列表 - Django

使用大型列表优化 Django 查询集调用?