专栏首页米扑专栏Python 学习入门(32)—— xrange/range

Python 学习入门(32)—— xrange/range

在Python中range和xrange是不同的,两者的区别是微妙的。为了简单起见,这里省略两个函数的可选参数start和step。range返回值和想象的一样:一个从0开始指定长度的连续整数序列。然而,xrange返回一个"xrange 对象",该对象非常类似于迭代器。如果你曾经研究过迭代器,则两者的区别就很明显。

下面是个例子:

range(1000000)

xrange(1000000)

range(1000000)会返回一个100万的整数元素的序列,而xrange(1000000)在本质上会返回一个迭代序列。显然xrange支持迭代,而range不支持。这种收益是很小的,因为"当需要元素的时候,xrange仍然要创建它们"。但是无论需要的序列多大,每次遍历时xrange消耗相同量的内存。在遍历极端的大序列时,这是相对于range的很大优势。另一个优势也是明显的:当你的代码在遍历已经产生的序列时调用break的话, xrange显然比range要好,因为xrange会消耗更少的内存。

这两个基本上都是在循环的时候用。

for i in range(0, 100):

print i

for i in xrange(0, 100):

print i

这两个输出的结果都是一样的,实际上有很多不同,range会直接生成一个list对象:

a = range(0,100)

print type(a)

print a

print a[0], a[1]

而xrange则不会直接生成一个list,而是每次调用返回其中的一个值

a = xrange(0,100)

print type(a)

print a

print a[0], a[1]

示例:

t1 = range(0, 100)
print type(t1)              # <type 'list'>
print t1[0],t1[1],t1[99]    # 0 1 99
print t1                    # [0, 1, 2, 3, 4, 5, 6, ..., 99]

t2 = xrange(0, 100)  
print type(t2)              # <type 'xrange'>
print t2[0],t2[1],t2[99]    # 0 1 99
print t2                    # xrange(100)

性能比较:

#!/usr/bin/env python
# -*- coding: utf-8 -*-

'''
@author: homer
@see: ithomer.net
'''

import time

def test_range(num):
    for i in range(0, num):
        #print i
        pass
        
def test_xrange(num):
    for i in xrange(0, num):
        #print i
        pass
    
    
NUM = 100000000

# test range
start = time.time()
test_range(NUM)
print("test_range() costTime: " + str(time.time() - start))

# test xrange
start = time.time()
test_xrange(NUM)
print("test_xrange() costTime: " + str(time.time() - start))

运行结果:

NUM = 100000000

test_range() costTime: 18.8114709854 test_xrange() costTime: 1.08277893066

NUM = 1000000

test_range() costTime: 0.0496039390564 test_xrange() costTime: 0.0162799358368

NUM = 10000

test_range() costTime: 0.000231027603149 test_xrange() costTime: 0.000118970870972

所以xrange做循环的性能比range好,尤其是返回很大的时候!

尽量用xrange吧,除非你是要返回一个列表。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 商业价值:苹果iTV,再一次改变世界?

      苹果(Apple)公司打算进军智能电视领域,这在行业里已经不是秘密,有关苹果智能电视的消息也是不绝于耳,结合苹果产品线的命名规则,苹果智能 电视基本上就是i...

    阳光岛主
  • GAE、SAE、BAE 对比分析

    目前,云服务很多,例如GAE、BAE、SAE、TAE、CAE、ACE、EC2、AZURE各种云。本文主要从以下几个方面对GAE、SAE和BAE的优劣进行分析。

    阳光岛主
  • 【leetcode】4Sum

    Given an array S of n integers, are there elements a, b, c, and d in S such that...

    阳光岛主
  • python xrange比range性

    range     函数说明:range([start,] stop[, step]),根据start与stop指定的范围以及step设定的步长,生成一个序列。...

    py3study
  • python: range & xrange 探究

    xrange 用法与 range 完全相同,所不同的是生成的不是一个list对象,而是一个生成器。

    JNingWei
  • 【推荐】数据科学家与数据科学。

    仅仅在几年前,数据科学家还不是一个正式确定的职业,然而一眨眼的工夫,这个职业就已经被誉为“今后十年IT行业最重要的人才”了。 一、数据科学家的起源 "数据科学"...

    小莹莹
  • jquery mobile 移动web(2)

    button 按钮   data-role="button" 将超链接变成button。   具有icon 图标的button 组件...

    用户1197315
  • 数据迁移流程的优化

    昨天做了一个数据迁移流程的优化,直到发生了一些严重的问题,才明显重视起来这个问题。

    jeanron100
  • 后台系统设计(上篇:选择)

    在单个选项下,存在多组互斥选项,且互斥选项组之间存在一定关系,可以考虑混用分段控件和常规按钮,由于分段控件在视觉上占用更大的面积,故给人在层级上更加置前。

    霖酱
  • pandas DataFrame运算的实现

    综合分析: 能够直接得出很多统计结果,count, mean, std, min, max 等

    砸漏

扫码关注云+社区

领取腾讯云代金券