美文网首页
Python3 - 实现迭代器协议

Python3 - 实现迭代器协议

作者: 惑也 | 来源:发表于2018-12-21 22:18 被阅读21次

问题

构建一个支持迭代操作的自定义对象,并找到一个能实现迭代协议的简单方法。

解决方案

在一个对象上,实现迭代操作最简单的方式是使用一个生成器函数。 实现一个以深度优先方式,遍历树形节点的生成器。示例:

class Node(object):
    def __init__(self, value):
        self._value = value
        self._children = []

    def __repr__(self):
        return 'Node({!r})'.format(self._value)

    def add_child(self, node):
        self._children.append(node)

    def __iter__(self):
        return iter(self._children)

    def depth_first(self):
        yield self
        for c in self:
            yield from c.depth_first()

# Example
if __name__ == '__main__':
    root = Node(0)
    child1 = Node(1)
    child2 = Node(2)
    root.add_child(child1)
    root.add_child(child2)
    child1.add_child(Node(3))
    child1.add_child(Node(4))
    child2.add_child(Node(5))

    for ch in root.depth_first():
        print(ch)
    # Outputs Node(0), Node(1), Node(3), Node(4), Node(2), Node(5)

示例代码中,depth_first() 方法简单直观。它首先返回自己本身,并迭代每一个子节点,通过yield from 语句,调用子节点的 depth_first()方法,返回对应元素。

讨论

Python的迭代协议要求一个 __iter__() 方法,返回一个特殊的迭代器对象, 这个迭代器对象实现了 __next__() 方法并通过 StopIteration 异常标识迭代的完成。 但是,实现这些通常会比较繁琐。 通常,将迭代器定义为一个生成器后一切迎刃而解。

相关文章

  • 迭代器和生成器 (Iterator & Generator)

    迭代器 迭代器对象要求支持迭代器协议的对象,在Python中,支持迭代器协议就是实现对象的__iter__()和n...

  • Python3 - 实现迭代器协议

    问题 构建一个支持迭代操作的自定义对象,并找到一个能实现迭代协议的简单方法。 解决方案 在一个对象上,实现迭代操作...

  • python迭代器(Iterator)

    迭代器(iterator)是实现了迭代协议(Iteration Protocol)对象。迭代协议包括两个方法: _...

  • 面试题三(3)

    1.什么叫 迭代器?(1)迭代器是一个实现了迭代器协议的对象,Python中的迭代器协议就是有next方法的对象会...

  • 迭代器和生成器

    1. 迭代器协议 由于生成器自动实现了迭代器协议,而迭代器协议对很多人来说,也是一个较为抽象的概念。所以,为了更好...

  • 迭代器、生成器

    迭代器对象 实现了迭代器协议的对象叫做迭代器对象,迭代器对象可以使用 next 和 __next__ 方法进行迭...

  • Python高级知识点学习(六)

    Python中的迭代协议 迭代协议有两个概念: 可迭代类型(Iterable) 迭代器(Iterator) 迭代器...

  • 迭代器与生成器

    迭代(iteration)与可迭代(iterable) 迭代器 迭代器协议(iterator protocol) ...

  • 生成器

    通过一致的方式遍历序列。这个特性是通过迭代器协议实现的,迭代器协议是一种令对象可遍历的通用方式。 当写下 for ...

  • 12.python迭代器与生成器

    迭代器 双下方法:很少直接调用的方法, 一般情况下,是通过其他语法触发的。迭代协议:内部实现了iter方法;迭代器...

网友评论

      本文标题:Python3 - 实现迭代器协议

      本文链接:https://www.haomeiwen.com/subject/ulzvkqtx.html