1

オブジェクトのリストを含むオブジェクトを反復処理することは可能ですか?

たとえば、次のクラスがあります

Class Page(object)

    def __init__(self, name):

        self.name = name
        self.pages = []

次に、新しい Page オブジェクトを作成し、それに他のページ オブジェクトを追加します。

page = Page('FirstPage')

apagepage = Page('FirstChild')

anotherpagepage = Page('SecondChild')

apagepage.pages.append(Page('FirstChildChild'))

apagepage.pages.append(Page('SecondChildChild'))

page.pages.append(apagepage)

page.pages.append(anotherpagepage)

私がやりたいことは

for thispage in page:
    print thispage.name

そして、次の出力を取得します

FirstPage
FirstChild
SecondChild
FirstChildChild
SecondChildChild

だから私はすべての第1レベルを取得し、次に第2レベル、次に第3レベルを取得します。

ただし、次の出力も見つかります

FirstPage
FirstChild
FirstChildChild
SecondChildChild
SecondChild
4

4 に答える 4

3

を定義できます。__str__

from itertools import chain

class Page(object):
    def __init__(self, name):
        self.name = name
        self.pages = []
    def __str__(self):
        return "\n".join(chain([self.name], map(str, self.pages)))

その後、あなたはただすることができますprint page

forループを使用したい場合は、イテレータを定義することもできます

class Page(object):
    def __init__(self, name):
        self.name = name
        self.pages = []
    def __iter__(self):
        yield self
        for page in self.pages:
            for i in page:
                yield i
于 2012-10-23T04:35:58.580 に答える
1

再帰的に実行します。

class Page(object):
    def __init__(self, name):
        self.name = name
        self.pages = []

    def __iter__(self):
        for p in self.get_children_pages(self):
            yield p

    def get_children_pages(self, start_page):
        result = [start_page.name]
        for this_page in start_page.pages:
            result.extend(self.get_children_pages(this_page))
        return result


>>>>for p in page:
....    print p

FirstPage
FirstChild
FirstChildChild
SecondChildChild
SecondChild
于 2012-10-23T04:28:28.080 に答える
0

再帰的に行う

def print_all_pages(page):
    print page.name
    if len(page.pages) == 0 then:
        return
    else:
        for child_page in page.pages:
            print_all_pages(child_page)

def print_pages(pages_collection):
    for page in pages_collection:
        print_all_pages(page)
于 2012-10-23T04:48:43.400 に答える
0
class Page(object):
    def __init__(self, name, pages=None):
        self.name = name
        self.pages = pages if pages is not None else []
    def __iter__(self):
        return iter(self.pages) # only immediate children
    def walk(self, topdown=True): # all pages recursively
        if topdown:
            yield self
        for page in self:
            yield from page.walk(topdown)
        if not topdown:
            yield self

yield fromPython <3.3 では、次のように置き換えることができます。

for subpage in page.walk(topdown):
    yield subpage

この場合。

page = Page('FirstPage', [
        Page('FirstChild', [
                Page('FirstChildChild'),
                Page('SecondChildChild'),
                ]),
        Page('SecondChild'),
        ])

for p in page.walk():
    print(p.name)

出力

FirstPage
FirstChild
FirstChildChild
SecondChildChild
SecondChild
于 2012-10-23T10:36:49.910 に答える