Printing a Tree data structure in Python

后端 未结 2 660
萌比男神i
萌比男神i 2020-12-15 18:17

I was looking for a possible implementation of tree printing, which prints the tree in a user-friendly way, and not as an instance of object.

I came across this solu

2条回答
  •  盖世英雄少女心
    2020-12-15 18:40

    Yes, move the __repr__ code to __str__, then call str() on your tree or pass it to the print statement. Remember to use __str__ in the recursive calls too:

    class node(object):
        def __init__(self, value, children = []):
            self.value = value
            self.children = children
    
        def __str__(self, level=0):
            ret = "\t"*level+repr(self.value)+"\n"
            for child in self.children:
                ret += child.__str__(level+1)
            return ret
    
        def __repr__(self):
            return ''
    

    Demo:

    >>> root = node('grandmother')
    >>> root.children = [node('daughter'), node('son')]
    >>> root.children[0].children = [node('granddaughter'), node('grandson')]
    >>> root.children[1].children = [node('granddaughter'), node('grandson')]
    >>> root
    
    >>> str(root)
    "'grandmother'\n\t'daughter'\n\t\t'granddaughter'\n\t\t'grandson'\n\t'son'\n\t\t'granddaughter'\n\t\t'grandson'\n"
    >>> print root
    'grandmother'
        'daughter'
            'granddaughter'
            'grandson'
        'son'
            'granddaughter'
            'grandson'
    

提交回复
热议问题