python中range()函数和xrange()函数浅析

版权声明:本文为博主原创文章。尊重原创,转载请标明:转自http://blog.csdn.net/hk_john https://blog.csdn.net/Hk_john/article/details/77982047

首先讲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()的参数和使用方法几乎相同,下面给出例子:
  • >>>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]
    >>>
    那么,range和xrange的根本区别在哪呢?
  • 在于例如我要生成一组足够大的数,但是我们并不知道需要用多少,也许只需要使用其中的10个数。假如使用range(1,1000000),这就需要计算所有的1-999999的数字,即使我们只需要使用1-10这几个数字。如果使用xrange(1,1000000)这系统并不会进行1000000次操作而是我们申请一个数时系统计算一次,这样就会大大地减少运行时间。
  • 例如我们进行下面的操作:
  • >>>zip(range(5),xrange(1000000))
    这个语句仅仅进行了5次操作。



展开阅读全文

没有更多推荐了,返回首页