如何删除Django中每个列表值后面的“L”

时间:2016-01-13 14:11:06

标签: python django django-orm

我做了一个查询来从模型中获取所有字段值。我将结果存储在查询集中。

ó ł ę ą ć

现在,当我过滤此查询集时:

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列表。

我看过这个,但找不到任何关于此事的内容。

4 个答案:

答案 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))**