python中class类的可迭代实现以及迭代函数

  1. 当定义一个普通的类时,指向类的实例默认情况下是不可迭代的,如下
In [3]: from collections import Iterable                                        
In [4]: class Fruit(object): 
   ...:     def __init__(self): 
   ...:         self.item = list() 
   ...:     def add(self,name): 
   ...:         self.item.append(name) 
   ...:                                                                         

In [5]: list1 = Fruit()                                                        

In [6]: isinstance(list1,Iterable)                                              
Out[6]: False
  1. 因此在这种情况下,当对一个类的实例想要使用for…in…循环进行遍历时,便会报不可迭代的错误,为此要对函数进行改造,使其具有可迭代性,且能正确进行迭代操作,改造结果如下
class Fruit():
    def __init__(self):
        self.item = list()
        # 为next函数计数器初始化
        self.count = 0

    def add(self,name):
        self.item.append(name)

	# 使函数具有可迭代性
    def __iter__(self):
        return self

    def __next__(self):
    	# 获取下一个数
        if self.count < len(self.item):
            result = self.item[self.count]
            self.count += 1
            return result
        else:
        # 遍历结束后,抛出异常,终止遍历
            raise StopIteration


list1 = Fruit()
list1.add("apple")
list1.add("banana")
list1.add("orange")

for item in list1:
    print(item)
  1. 下面详细解释,python在调用for…in…循环进行遍历时,对于类的实例的访问过程:
    ——检查该类是否具有迭代性,即调用类中的iter()方法
    —— 通过iter()函数获取类中的迭代器,通过调用迭代器中的next()方法,获取下一个值,并赋值给result
    ——遇到StopIteration的异常后循环结束
  2. 可将上段代码中对类的定义拆分成两个类来看,更加直观:
 class Fruit():
    def __init__(self):
        self.item = list()

    def add(self,name):
        self.item.append(name)

	# 使函数具有可迭代性
    def __iter__(self):
        return myIterator(self)
  1. 以上是对Fruit类的定义,在其中定义iter()方法,使其具有可迭代性,通过iter()函数的返回值调用myIterator()迭代器;并对该迭代器传递一个self参数,使迭代器可以指向到自身。这部分代码使得类具有迭代性。
class myIterator():

    def __init__(self,fru):
        self.fru = fru
        self.count = 0

    def __next__(self):
        if self.count < len(self.fru.item):
            result = self.fru.item[self.count]
            self.count += 1
            return result
        else:
            raise StopIteration
  1. 以上为Fruit类的迭代器通过参数fru的赋值,在迭代器中使self.fru变量指向Fruit类,从而在next函数中可以对Fruit类中的实例进行访问控制 。这部分代码完成了类的迭代器,保证可以调用next函数。
  • 11
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Python迭代器是一种对象,可以逐个访问集合的元素,而不需要事先知道集合的大小。迭代器提供了一种更简洁、更高效的处理集合数据的方式。 要创建一个迭代器,你可以定义一个,并在实现两个方法:`__iter__`和`__next__`。`__iter__`方法返回迭代器对象本身,而`__next__`方法返回集合的下一个元素。 下面是一个简单的示例,展示了如何创建一个迭代器来遍历一个列表: ```python class MyIterator: def __init__(self, collection): self.collection = collection self.index = 0 def __iter__(self): return self def __next__(self): if self.index < len(self.collection): item = self.collection[self.index] self.index += 1 return item else: raise StopIteration # 创建一个列表 my_list = [1, 2, 3, 4, 5] # 创建一个迭代器对象 my_iterator = MyIterator(my_list) # 使用迭代器遍历列表 for item in my_iterator: print(item) ``` 在上面的示例,我们定义了一个名为`MyIterator`的迭代器,其`collection`参数是要遍历的集合。`__iter__`方法返回迭代器对象本身,而`__next__`方法根据当前索引返回下一个元素。当没有更多元素可返回时,我们引发`StopIteration`异常来结束迭代。 可以通过`for`循环来遍历迭代器对象,也可以使用内置函数`next()`来逐个获取元素。 除了自定义迭代器之外,Python还提供了许多内置的可迭代对象和迭代器,如列表、元组、字典、集合等。你可以直接使用它们进行迭代操作,而不需要自己实现迭代器。例如,使用`for`循环遍历列表时,实际上是使用了列表的迭代器
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Joshua.Lee

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值