发布于2019-08-07 19:12 阅读(870) 评论(0) 点赞(4) 收藏(0)
一般使用for循环的顺序:
先创建一个迭代器:列表,并且列表内已存在数据
接着使用 for循环遍历列表
但这样存在一个问题,假如列表内的数据量很大,这样还未使用for循环便已经被列表占用很大的资源
这时我们就可以将这个迭代器做成一个生成数据的迭代器,而非只是占用大资源的数据,从而减少资源占用
python2里有range和xrange,而前者和后者区别是,range就像是那个占用大资源的数据,xrange则是生产数据的迭代器
python3并没有xrange,它的range就是一个生产数据的迭代器
同理,list(),和tuple(),之间并非简单的转换,而是创建了一个空列表/元组,然后不断将原列表/元组的数据添加到空列表/元组中,也就是生产数据的迭代器
例子中 for循环遍历的nums是已经存在需要遍历的所有数据
# 未使用迭代器的斐波那契数列例子 nums = list() a = 0 b = 1 i = 0 while i < 10: nums.append(a) a, b = b, a+b i += 1 for num in nums: print(num)
例子中 for循环遍历的nums需要用几个到才去生产几个(即每遍历获取一个num,才生产一个数据)
# 使用了迭代器的斐波那契数列的例子
# for 循环的对象并不是个内容,而是生成内容的方法,这样做可以节省资源 class Fibonacci(object): def __init__(self, all_num): self.all_num = all_num self.current_num = 0 self.a = 0 self.b = 1 def __iter__(self): return self def __next__(self): if self.current_num < self.all_num: ret = self.a self.a, self.b = self.b, self.a+self.b self.current_num += 1 return ret else: raise StopIteration fibo = Fibonacci(10) for num in fibo: print(num)
作者:23hdsdh
链接:https://www.pythonheidong.com/blog/article/12368/06fd0e870bbb229c0292/
来源:python黑洞网
任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任
昵称:
评论内容:(最多支持255个字符)
---无人问津也好,技不如人也罢,你都要试着安静下来,去做自己该做的事,而不是让内心的烦躁、焦虑,坏掉你本来就不多的热情和定力
Copyright © 2018-2021 python黑洞网 All Rights Reserved 版权所有,并保留所有权利。 京ICP备18063182号-1
投诉与举报,广告合作请联系vgs_info@163.com或QQ3083709327
免责声明:网站文章均由用户上传,仅供读者学习交流使用,禁止用做商业用途。若文章涉及色情,反动,侵权等违法信息,请向我们举报,一经核实我们会立即删除!