返回顶部
首页 > 资讯 > 后端开发 > Python >迭代器的应用以及说明的问题
  • 251
分享到

迭代器的应用以及说明的问题

迭代 2023-01-30 23:01:22 251人浏览 八月长安

Python 官方文档:入门教程 => 点击学习

摘要

一般使用for循环的顺序:   先创建一个迭代器:列表,并且列表内已存在数据   接着使用 for循环遍历列表   但这样存在一个问题,假如列表内的数据量很大,这样还未使用for循环便已经被列表占用很大的资源 这时我们就可以将这个迭代器做

一般使用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)

 

--结束END--

本文标题: 迭代器的应用以及说明的问题

本文链接: https://lsjlt.com/news/181149.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作