Извлечь отношения родительского потомка с уровнем из той же таблицы - PullRequest
0 голосов
/ 09 октября 2019

Привет, я новичок в django и python.

# function for fecthing the child
def get_childern(request, username):
    Q = list(Profile.objects.filter(sponsor_id__exact=username))
    populate(request, Q, username)


# Iterate the Queryset 
def populate(request, quesryset, username):
    if quesryset:
        messages.success(request, username+' has '+str(len(quesryset))+' child')
        messages.info(request, quesryset)
        for user in quesryset:
            get_childern(request, user.user_id)
    else:
        messages.warning(request, 'User '+username+' has no child')
        return False

# calling all children 
get_childern(request, username)

и я хочу добавить уровень, как его разделить дальше.

Пожалуйста, помогите мне, инвестируйте многовремя и разум. Спасибо всем:)

1 Ответ

0 голосов
/ 15 октября 2019

Я нашел решение, если кто-то хочет дать отзыв или идею для лучшего решения, прокомментируйте здесь. Ценю всех:)

# for return a child query-set
def get_childern(request, username):
    Q = Profile.objects.filter(sponsor_id__exact=username)
    return Q


level = int(1) # set according to need 
tree_set = {}


# iterate the queryset and call itself
# recursion - set the level to control 
def iterate_object(request, quesryset):
    global tree_set
    outer_count = int(0)
    inner_count = int(0)
    level_tree = []
    for users in quesryset:
        outer_count = outer_count + 1
        # messages.info(request, users.user_id)
        Qs = get_childern(request, users.user_id)
        if Qs:
            for child in Qs:
                inner_count = inner_count + 1
                level_tree.append(child)

            # count = count + len(Qs)
            # messages.warning(request, Qs)
        else:
            # messages.warning(request, 'No child')
            pass
    else:
        # messages.error(request, 'Total child at level 2 => ' + str(count))
        # messages.info(request, outer_count)
        # messages.success(request, inner_count)
        global level
        level = level + 1
        # set the numeric value to control the level
        if level <= 10: 
            tree_set.update({level: level_tree})
            iterate_object(request, level_tree)
            return tree_set
        else:
            # messages.warning(request, 'else part')
            pass

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...