每当我尝试为这样的变量分配范围时:
Var1 = range(10, 50)
然后尝试打印变量:
Var1 = range(10, 50)
print(Var1)
它只是打印'范围(10,50)'而不是列表中的所有数字。这是为什么?
答案 0 :(得分:13)
多数民众赞成因为range
在Python 3中返回一个范围对象。将它放在list
中以使其按照您的意愿行事:
>>> Var1 = range(10, 50)
>>> print(list(Var1))
[10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31,
32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49]
>>>
答案 1 :(得分:8)
您应该了解一下幕后发生的事情。
在python 3中,range
返回一个range
对象,而不是您可能期望的列表。 (n.b. python 3的range
是python 2的xrange
)
#python 2
>>> type(range(5))
<type 'list'>
#python 3
>>> type(range(5))
<class 'range'>
这是什么意思?好吧,range对象只是一个迭代器 - 你需要强制它迭代才能得到它的内容。这对新生儿来说可能听起来很烦人,但事实证明它非常有用。
>>> import sys
>>> sys.getsizeof(range(5))
24
>>> sys.getsizeof(range(1000000))
24
以这种方式做事的最大优势:持续(微小)内存占用。出于这个原因,标准库中的许多事物只返回迭代器。权衡的是,如果您只是想看迭代范围,则必须强制它进行迭代。最常见的成语是list(range(n))
。还有理解,for
循环和更深奥的方法。迭代器是学习python的重要部分,所以习惯它们!
答案 2 :(得分:-1)
这是Python 3.0中已更改的内容。您可以在Python 2.7中重新创建类似的函数,如此,
def range(low, high=None):
if high == None:
low, high = 0, low
i = low
while i < high:
yield i
i += 1
这样做的好处是,列表不必在使用之前创建。
for i in range(1,999999):
text = raw_input("{}: ".format(i))
print "You said {}".format(text)
其中的工作原理如下:
1: something
You said something
2: something else
You said something else
3: another thing
You said another thing
在Python 3.X中,如果我们永远不会到达循环的末尾(999997次迭代),它将永远不会计算所有项目。在Python 2.7中,它必须最初构建整个范围。在一些较旧的Python实现中,这非常慢。