首页 > 编程语言 >python迭代器和生成器

python迭代器和生成器

时间:2024-01-18 16:12:44浏览次数:30  
标签:__ 迭代 python self 生成器 next print

迭代器:

定义:

迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束。迭代器只能往前不会后退。

迭代器有两个基本的方法:iter() 和 next()。

字符串,列表或元组对象都可用于创建迭代器:

ex:

  #!/usr/bin/python3

  list=[1,2,3,4]
  it = iter(list)    # 创建迭代器对象
  for x in it:
      print (x, end=" ")
  输出:1 2 3 4

把类作为迭代器的方法:

要把类作为迭代器,得在类中实现两个方法 iter() 与 next()
iter() 方法返回一个特殊的迭代器对象, 这个迭代器对象实现了 next() 方法并通过 StopIteration 异常标识迭代的完成。

next() 方法(Python 2 里是 next())会返回下一个迭代器对象。

创建一个返回数字的迭代器,初始值为 1,逐步递增 1:

ex:

  class MyNumbers:
    def __iter__(self):
      self.a = 1
      return self

    def __next__(self):
      x = self.a
      self.a += 1
      return x

  myclass = MyNumbers()
  myiter = iter(myclass)

  print(next(myiter))
  print(next(myiter))
  print(next(myiter))
  print(next(myiter))
  print(next(myiter))

  输出结果为:
  1
  2
  3
  4
  5

stoplteration异常:

StopIteration 异常用于标识迭代的完成,防止出现无限循环的情况,在 next() 方法中我们可以设置在完成指定循环次数后触发 StopIteration 异常来结束迭代。
在迭代20次后停止执行:

		class MyNumbers:
		  def __iter__(self):
		    self.a = 1
		    return self
		 
		  def __next__(self):
		    if self.a <= 20:
		      x = self.a
		      self.a += 1
		      return x
		    else:
		      raise StopIteration
		 
		myclass = MyNumbers()
		myiter = iter(myclass)
		 
		for x in myiter:
		  print(x)
        结果是输出1到20

生成器:

定义:

使用了yield关键字的函数被称为生成器(generator)

yield 是一个关键字,用于定义生成器函数,生成器函数是一种特殊的函数,可以在迭代过程中逐步产生值,而不是一次性返回所有结果。

跟普通函数不同的是,生成器是一个返回迭代器的函数,只能用于迭代操作,更简单点理解生成器就是一个迭代器。

当在生成器函数中使用 yield 语句时,函数的执行将会暂停,并将 yield 后面的表达式作为当前迭代的值返回。

然后,每次调用生成器的 next() 方法或使用 for 循环进行迭代时,函数会从上次暂停的地方继续执行,直到再次遇到 yield 语句。这样,生成器函数可以逐步产生值,而不需要一次性计算并返回所有结果。

调用一个生成器函数,返回的是一个迭代器对象。

ex:
def countdown(n):
while n > 0:
yield n
n -= 1

	# 创建生成器对象
	generator = countdown(5)
	 
	# 通过迭代生成器获取值
	print(next(generator))  # 输出: 5
	print(next(generator))  # 输出: 4
	print(next(generator))  # 输出: 3
	 
	# 使用 for 循环迭代生成器
	for value in generator:
	    print(value)  # 输出: 2 1

标签:__,迭代,python,self,生成器,next,print
From: https://www.cnblogs.com/tomako123/p/17972665

相关文章

  • python的whisper工具包
    实现Python的Whisper工具包作为一名经验丰富的开发者,你需要教一位刚入行的小白如何实现Python的Whisper工具包。下面是整个实现的步骤概述:确定需求:首先需要明确Whisper工具包的功能和用途,以便为其设计合适的代码结构。安装必要的库:使用pip命令安装Python的相关库,如numpy、panda......
  • Python whisper识别
    Pythonwhisper识别Pythonwhisper识别是一个用于语音识别的开源Python库。它基于Google的语音识别API,通过将语音转换为文本,实现对语音数据的处理和分析。Pythonwhisper识别可以应用于各种场景,例如语音助手、语音命令控制和语音转写等。安装Pythonwhisper识别要使用Pythonwh......
  • python whisper没有分段
    PythonWhisper没有分段实现方法1.概述在本文中,我将向你介绍如何在Python中实现"Whisper没有分段"的功能。作为一名经验丰富的开发者,我将引导你完成这个任务,并提供每一步需要执行的代码示例和注释。2.任务流程下表显示了实现"Whisper没有分段"功能的步骤。我们将按照这些步骤......
  • python使用whisper用gpu进行计算
    如何使用Python和Whisper进行GPU计算引言:在计算机科学领域,GPU(图形处理器)已经成为进行高性能计算的重要工具。Python作为一种简单易用且功能强大的编程语言,也可以与GPU一起使用,实现各种复杂的计算任务。本文将向刚入行的小白介绍如何使用Python和Whisper库进行GPU计算。流程图:下......
  • python虚拟环境系列(五):pycharm中快速切换环境
     pycharm版本选择说明,pycharm中快速切换环境这个功能在比较新的版本中才有我目前版本比较老 所以卸载了:  官网下载最新社区版本:https://www.jetbrains.com.cn/en-us/pycharm/download/?section=windows 当前最新版本是:  安装最新版本pycharm基本上一路下一步即可 我做了如......
  • 【Python】datetime 时区转换, celery 结果 date_done比东八区晚8小时
    1.通过AsyncResult获取任务结果对象fromcelery.resultimportAsyncResultimportpytzfromdatetimeimportdatetime#根据任务ID获取任务结果对象result=AsyncResult(task_id)2.将UTC时间转为东八区时间#获取完成时间(UTC时间)date_done_utc=result.date_done......
  • (Python)每日代码||2024.1.18
    m=10a=10print(id(m))print(id(a))'''输出140713874176728140713874176728'''print()a=1b=2c=3d=a+bprint('a(1)\t'+str(id(a)))print('b(2)\t'+str(id(b)))print('c(3)\t'+str(id......
  • Python中sys中的path和moduls作用
    #导入内置模块sysimportsys1、sys.pathsys.path变量包含了一个用于搜索模块的目录列表。当试图导入一个模块时,Python解释器会按照sys.path中列出的路径顺序取搜索对应的模块文件。常见的sys.path包含以下几个位置:首先是当前目录,即包含你当前运行脚本的目录。其次是PYTHON......
  • 6种Python代码生成exe工具
    6种Python代码生成exe工具auto-py-to-exe界面安装pipinstallauto-py-to-execmd命令框输入:auto-py-to-exe 1、pyinstallerpyinstaller是一个流行的Python打包工具,它可以将Python代码打包成独立的可执行文件。命令行中输入以下命令:pyinstalleryour_script.py这将......
  • python pyqt6 QComboBox 圆角边框
    圆角边框周围显示黑色直角QComboBox 新增如下设定即可xxx_source.view().window().setWindowFlag(Qt.WindowType.NoDropShadowWindowHint)xxx_source.view().window().setWindowFlag(Qt.WindowType.FramelessWindowHint)xxx_source.view().window().setAttribute(Qt.Widge......