我有一个带有Django查询集过滤的怪癖(?):
ipdb> MagazineIssue.objects.filter(id__in=l_magazines.values_list('id'))
Out[0]: []
或
ipdb> MagazineIssue.objects.filter(id__in=[l_magazine.id for l_magazine in l_magazines])
Out[0]: [<MagazineIssue: Architecture Australia, Jan 1995 (#1)>]
和
ipdb> l_magazines.values_list('id')
Out[0]: [(1,)]
ipdb> [l_magazine.id for l_magazine in l_magazines]
Out[0]: [1]
那么,如何使用values_list()? (生产):
[1]
或者是python list comprehension'走的路'?
答案 0 :(得分:58)
试试l_magazines.values_list('id', flat=True)
。这将返回一个id列表,而不是单个id元组列表。
答案 1 :(得分:2)
需要注意的一点是,值/ values_list与列表理解的行为存在差异:
选择错误的一个会导致不必要的数据库命中,或者不必要的操作,这取决于你想要做什么。