/ Design Patterns / Behavioral patterns / Visitor Visitor Design Pattern in Python Back to Visitor description """ Represent an operation to be performed on the elements of an object structure. Visitor lets you define a new operation without changing the classes of the elements on which it operates. """ import abc class Element(metaclass=abc.ABCMeta): """ Define an Accept operation that takes a visitor as an argument. """ @abc.abstractmethod def accept(self, visitor): pass class ConcreteElementA(Element): """ Implement an Accept operation that takes a visitor as an argument. """ def accept(self, visitor): visitor.visit_concrete_element_a(self) class ConcreteElementB(Element): """ Implement an Accept operation that takes a visitor as an argument. """ def accept(self, visitor): visitor.visit_concrete_element_b(self) class Visitor(metaclass=abc.ABCMeta): """ Declare a Visit operation for each class of ConcreteElement in the object structure. The operation's name and signature identifies the class that sends the Visit request to the visitor. That lets the visitor determine the concrete class of the element being visited. Then the visitor can access the element directly through its particular interface. """ @abc.abstractmethod def visit_concrete_element_a(self, concrete_element_a): pass @abc.abstractmethod def visit_concrete_element_b(self, concrete_element_b): pass class ConcreteVisitor1(Visitor): """ Implement each operation declared by Visitor. Each operation implements a fragment of the algorithm defined for the corresponding class of object in the structure. ConcreteVisitor provides the context for the algorithm and stores its local state. This state often accumulates results during the traversal of the structure. """ def visit_concrete_element_a(self, concrete_element_a): pass def visit_concrete_element_b(self, concrete_element_b): pass class ConcreteVisitor2(Visitor): """ Implement each operation declared by Visitor. Each operation implements a fragment of the algorithm defined for the corresponding class of object in the structure. ConcreteVisitor provides the context for the algorithm and stores its local state. This state often accumulates results during the traversal of the structure. """ def visit_concrete_element_a(self, concrete_element_a): pass def visit_concrete_element_b(self, concrete_element_b): pass def main(): concrete_visitor_1 = ConcreteVisitor1() concrete_element_a = ConcreteElementA() concrete_element_a.accept(concrete_visitor_1) if __name__ == "__main__": main() Support our free website and own the eBook! 22 design patterns and 8 principles explained in depth 406 well-structured, easy to read, jargon-free pages 228 clear and helpful illustrations and diagrams An archive with code examples in 4 languages All devices supported: EPUB/MOBI/PDF formats Learn more...