如何在Python中使用range()生成以下列表?
[9, 8, 7, 6, 5, 4, 3, 2, 1, 0]
如何在Python中使用range()生成以下列表?
[9, 8, 7, 6, 5, 4, 3, 2, 1, 0]
当前回答
你可以使用range(10)[::-1],它和range(9, -1, -1)是一样的,而且可以说可读性更强(如果你熟悉常见的序列[::-1]Python习语)。
其他回答
除了可读性,反向(range(n))似乎比range(n)[::-1]更快。
$ python -m timeit "reversed(range(1000000000))"
1000000 loops, best of 3: 0.598 usec per loop
$ python -m timeit "range(1000000000)[::-1]"
1000000 loops, best of 3: 0.945 usec per loop
如果有人想知道的话:)
使用reversed()函数:
reversed(range(10))
这更有意义。
更新:
如果你想让它是一个列表(正如btk指出的那样):
list(reversed(range(10)))
更新:
如果您希望仅使用range来实现相同的结果,则可以使用它的所有参数。范围(开始,停止,步长)
例如,要生成一个列表[5,4,3,2,1,0],您可以使用以下命令:
range(5, -1, -1)
这可能不太直观,但正如评论所提到的,这是更有效的,并且是反转列表的正确使用范围。
因为range(n)生成了一个可迭代对象,所以你可以做各种各样的事情来产生你想要的结果,比如:
range(n)[::-1]
如果循环没问题,我们可以创建一个队列:
a = []
for i in range(n):
a.insert(0,a)
return a
或者可以使用reverse()方法:
reverse(range(n))
range(9,-1,-1)
[9, 8, 7, 6, 5, 4, 3, 2, 1, 0]
这个问题中的需求需要一个降序为10的整数列表 秩序。那么,让我们用python生成一个列表。
# This meets the requirement.
# But it is a bit harder to wrap one's head around this. right?
>>> range(10-1, -1, -1)
[9, 8, 7, 6, 5, 4, 3, 2, 1, 0]
# let's find something that is a bit more self-explanatory. Sounds good?
# ----------------------------------------------------
# This returns a list in ascending order.
# Opposite of what the requirement called for.
>>> range(10)
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
# This returns an iterator in descending order.
# Doesn't meet the requirement as it is not a list.
>>> reversed(range(10))
<listreverseiterator object at 0x10e14e090>
# This returns a list in descending order and meets the requirement
>>> list(reversed(range(10)))
[9, 8, 7, 6, 5, 4, 3, 2, 1, 0]