我做了一个查询来从模型中获取所有字段值。我将结果存储在查询集中。
ó ł ę ą ć
现在,当我过滤此查询集时:
queryset=Books.objects.filter(book_type="comic")
将列表打印为:
query=queryset.filter(~Q(auther_id=1))
autherList=[]
for q in query:
autherList.append(q.auther_id)
print autherList
我的问题是:这个L表示什么以及如何删除它以获得一个简单的ID列表。
我看过这个,但找不到任何关于此事的内容。
答案 0 :(得分:10)
L
表示项目属于long
类型。
底层数据库库(mysql可能是?)正在从db中获取long
类型时创建它们。所以它们是long
而不是普通的int
。
您可以使用int
功能将它们转换为整数。
>>> lng_number = 23L
>>> int_num = int(lng_number)
>>> int_num
23
如果所有值均为long
类型,则可以使用map
,如下所示:
>>> long_list = [1L, 3L, 10L]
>>> int_list = map(int, long_list)
>>> int_list
[1, 3, 10]
>>>
答案 1 :(得分:3)
这不是文字L
,它代表数据类型long
。它只是一个命令行表示,您不必担心它,因为它只会为您的模型id
字段保留更多数字。
答案 2 :(得分:3)
我试过这个并且有效
>>> a = [3L, 4L, 9L, 13L, 53L, 53L, 102L, 111L, 111L, 111L, 111L]
>>> b = map(int,a)
>>> b
[3, 4, 9, 13, 53, 53, 102, 111, 111, 111, 111]
但是你不必担心它,因为Python将其视为数字
>>> a = [3L, 4L, 9L, 13L, 53L, 53L, 102L, 111L, 111L, 111L, 111L]
>>> b = [c*2 for c in a]
>>> b
[6L, 8L, 18L, 26L, 106L, 106L, 204L, 222L, 222L, 222L, 222L]
答案 3 :(得分:1)
Try this one
[3L, 4L, 9L, 13L, 53L, 53L, 102L, 111L, 111L, 111L, 111L]
use this ::
remove_extra = [int(item_list) for item_list in remove_extra]
****** if you want to remove duplicate value from list then use **set()**
like this::
**list(set(remove_extra))**