• python3没有了xrange


    升级到python3的同学应该会注意到以前经常用的xrange没了!

    是的,python3的range就是xrange。直接看效果!

    1.  
      Python 2.7.13 (v2.7.13:a06454b1afa1, Dec 17 2016, 20:53:40) [MSC v.1500 64 bit (AMD64)] on win32
    2.  
      Type "help", "copyright", "credits" or "license" for more information.
    3.  
      >>> type(range(10))
    4.  
      <type 'list'>

    python2中,range的返回值是list,这意味着内存将会分布相应的长度的空间给list。

    1.  
      >>> print(sys.version)
    2.  
      3.5.3 (v3.5.3:1880cb95a742, Jan 16 2017, 16:02:32) [MSC v.1900 64 bit (AMD64)]
    3.  
      >>> type(range(10))
    4.  
      <class 'range'>


    python3中返回的是一个对象,并没有将数据完全实例化,所以内存中只有一个对象的空间,对性能优化还是很有帮助的。

    其实类似的改动是有很多的,例如:字典的items.

    1.  
      >>> print(sys.version)
    2.  
      2.7.13 (v2.7.13:a06454b1afa1, Dec 17 2016, 20:53:40) [MSC v.1500 64 bit (AMD64)]
    3.  
      >>> a={'x':1}
    4.  
      >>> type(a.items())
    5.  
      <type 'list'>
    1.  
      >>> print(sys.version)
    2.  
      3.5.3 (v3.5.3:1880cb95a742, Jan 16 2017, 16:02:32) [MSC v.1900 64 bit (AMD64)]
    3.  
      >>> a={'x':1}
    4.  
      >>> type(a.items())
    5.  
      <class 'dict_items'>



    当然了你也可以在python3写一个xrange(多此一举:-P)

      1.  
        def xrange(x):
      2.  
            n=0
      3.  
            while n<x:
      4.  
                yield n
      5.  
                n+=1
      6.  

  • 相关阅读:
    总结
    ElasticSearch课件1.22
    clickhouse1.0.5
    大数据实时项目(ads层)
    大数据实时项目(dws层)1.2
    大数据实时项目(日活)1.6.1
    01_大数据技术之Spark入门(2.1)
    03_大数据技术之SparkSql(2.0)
    04_大数据技术之SparkStreaming(2.0)
    05_大数据技术之Spark内核解析(1.1)
  • 原文地址:https://www.cnblogs.com/xiaoboge/p/9683535.html
Copyright © 2020-2023  润新知