首先讲range(),其语法为:
range(start, stop[, step])
- start: 计数从 start 开始。默认是从 0 开始。例如range(5)等价于range(0, 5);
- end: 计数到 end 结束,但不包括 end。例如:range(0, 5) 是[0, 1, 2, 3, 4]没有5
- step:步长,默认为1。例如:range(0, 5) 等价于 range(0, 5, 1)、
- xrange()函数与range()的参数和使用方法几乎相同,下面给出例子:
-
那么,range和xrange的根本区别在哪呢?>>>xrange(8) xrange(8) >>> list(xrange(8)) [0, 1, 2, 3, 4, 5, 6, 7] >>> range(8) # range 使用 [0, 1, 2, 3, 4, 5, 6, 7] >>> xrange(3, 5) xrange(3, 5) >>> list(xrange(3,5)) [3, 4] >>> range(3,5) # 使用 range [3, 4] >>> xrange(0,6,2) xrange(0, 6, 2) # 步长为 2 >>> list(xrange(0,6,2)) [0, 2, 4] >>>
- 在于例如我要生成一组足够大的数,但是我们并不知道需要用多少,也许只需要使用其中的10个数。假如使用range(1,1000000),这就需要计算所有的1-999999的数字,即使我们只需要使用1-10这几个数字。如果使用xrange(1,1000000)这系统并不会进行1000000次操作而是我们申请一个数时系统计算一次,这样就会大大地减少运行时间。
- 例如我们进行下面的操作:
-
这个语句仅仅进行了5次操作。>>>zip(range(5),xrange(1000000))