Менеджер недоступен через экземпляры модели django

У меня возникает ошибка с django и их пользовательскими менеджерами. У меня есть этот пользовательский менеджер:

class CallManager(models.Manager):
    def get_queryset(self):
        return super(CallManager, self).get_queryset().filter(is_active=True)

class Call(models.Model):
    ...

    # Data            
    is_active = models.BooleanField(default=True)

    # Managers
    objects = models.Manager() # Default
    active = CallManager() # Active calls

Итак, теперь я пытаюсь получить данные из views.py (call/views.py)

# Call list
def call_list(request):
    list = Call.objects.all() # Error here
    render(request, 'call/call_list.html', {'list': list})

Когда Call.objects.all() выполняется, django показывает это сообщение:

Manager isn't accessible via Call instances

Я понятия не имею, что здесь происходит.

заранее спасибо

РЕДАКТИРОВАТЬ: модели

# Relations
#country = models.ManyToManyField...
individual = models.ManyToManyField...
project = models.ForeignKey(Project, on_delete=models.CASCADE)
criteria = models.ManyToManyField...
# Data
call_name = models.CharField(max_length=20, default=None)
start_date = models.DateField(default=None)
end_date = models.DateField(default=None, null=True, blank=True)
is_active = models.BooleanField(default=True)
# Creation
created_at = models.DateTimeField(auto_now_add=True, null=True)
modified_at = models.DateTimeField(auto_now=True, blank=True)
# Managers
objects = models.Manager() # Default
active = CallManager() # Active calls

Проследить:

TypeError: 'Call' object is not subscriptable

Во время обработки вышеупомянутого исключения произошло другое исключение:

Traceback (most recent call last):
  File "path....virtualenvs/apolo_venviorment/lib/python3.6/site-packages/django/core/handlers/exception.py", line 35, in inner
    response = get_response(request)
  File "path....virtualenvs/apolo_venviorment/lib/python3.6/site-packages/django/core/handlers/base.py", line 128, in _get_response
    response = self.process_exception_by_middleware(e, request)
  File "path...virtualenvs/apolo_venviorment/lib/python3.6/site-packages/django/core/handlers/base.py", line 126, in _get_response
    response = wrapped_callback(request, *callback_args, **callback_kwargs)
  File "path.../call/views.py", line 27, in call_list
    return render(request, 'call/call_list.html', {'list': list})
  File "path....virtualenvs/apolo_venviorment/lib/python3.6/site-packages/django/shortcuts.py", line 36, in render
    content = loader.render_to_string(template_name, context, request, using=using)
  File "path....virtualenvs/apolo_venviorment/lib/python3.6/site-packages/django/template/loader.py", line 62, in render_to_string
    return template.render(context, request)
  File "path....virtualenvs/apolo_venviorment/lib/python3.6/site-packages/django/template/backends/django.py", line 61, in render
    return self.template.render(context)
  File "path....virtualenvs/apolo_venviorment/lib/python3.6/site-packages/django/template/base.py", line 175, in render
    return self._render(context)
  File "path....virtualenvs/apolo_venviorment/lib/python3.6/site-packages/django/test/utils.py", line 98, in instrumented_test_render
    return self.nodelist.render(context)
  File "path....virtualenvs/apolo_venviorment/lib/python3.6/site-packages/django/template/base.py", line 943, in render
    bit = node.render_annotated(context)
  File "path....virtualenvs/apolo_venviorment/lib/python3.6/site-packages/django/template/base.py", line 910, in render_annotated
    return self.render(context)
  File "path....virtualenvs/apolo_venviorment/lib/python3.6/site-packages/django/template/loader_tags.py", line 155, in render
    return compiled_parent._render(context)
  File "path....virtualenvs/apolo_venviorment/lib/python3.6/site-packages/django/test/utils.py", line 98, in instrumented_test_render
    return self.nodelist.render(context)
  File "path...virtualenvs/apolo_venviorment/lib/python3.6/site-packages/django/template/base.py", line 943, in render
    bit = node.render_annotated(context)
  File "/Users/Jotadrive/.virtualenvs/apolo_venviorment/lib/python3.6/site-packages/django/template/base.py", line 910, in render_annotated
    return self.render(context)
  File "path....virtualenvs/apolo_venviorment/lib/python3.6/site-packages/django/template/loader_tags.py", line 67, in render
    result = block.nodelist.render(context)
  File "path....virtualenvs/apolo_venviorment/lib/python3.6/site-packages/django/template/base.py", line 943, in render
    bit = node.render_annotated(context)
  File "path....virtualenvs/apolo_venviorment/lib/python3.6/site-packages/django/template/base.py", line 910, in render_annotated
    return self.render(context)
  File "path....virtualenvs/apolo_venviorment/lib/python3.6/site-packages/django/template/defaulttags.py", line 211, in render
    nodelist.append(node.render_annotated(context))
  File "path....virtualenvs/apolo_venviorment/lib/python3.6/site-packages/django/template/base.py", line 910, in render_annotated
    return self.render(context)
  File "path....virtualenvs/apolo_venviorment/lib/python3.6/site-packages/django/template/base.py", line 993, in render
    output = self.filter_expression.resolve(context)
  File "path....virtualenvs/apolo_venviorment/lib/python3.6/site-packages/django/template/base.py", line 676, in resolve
    obj = self.var.resolve(context)
  File "path....virtualenvs/apolo_venviorment/lib/python3.6/site-packages/django/template/base.py", line 802, in resolve
    value = self._resolve_lookup(context)
  File "path...virtualenvs/apolo_venviorment/lib/python3.6/site-packages/django/template/base.py", line 843, in _resolve_lookup
    current = getattr(current, bit)
  File "path....virtualenvs/apolo_venviorment/lib/python3.6/site-packages/django/db/models/manager.py", line 178, in __get__
    raise AttributeError("Manager isn't accessible via %s instances" % cls.__name__)
AttributeError: Manager isn't accessible via Call instances
[19/Jul/2018 18:13:12] "GET /call/list/ HTTP/1.1" 500 200797

person Jotadrive    schedule 19.07.2018    source источник
comment
Похоже, вы переопределили имя Call одним экземпляром. Можете ли вы добавить полный код view.py?   -  person neverwalkaloner    schedule 19.07.2018
comment
В views.py больше нету, у меня просто импорт: from .models import Call   -  person Jotadrive    schedule 19.07.2018
comment
Хм.. А как насчет ваших моделей? У вас есть код после класса Call?   -  person neverwalkaloner    schedule 19.07.2018
comment
Показать полную трассировку.   -  person Daniel Roseman    schedule 19.07.2018
comment
Все еще не мог понять, что здесь происходит... я потерялся   -  person Jotadrive    schedule 19.07.2018


Ответы (2)


Решение: Кажется, это был конфликт между полем в моей модели и менеджером. Поле было названо «активным». Затем я изменил это:

objects = models.Manager()
active = CallManager()

Для этого:

objects = models.Manager() # Default manager
objects_active = CallManager() # Custom manager

Надежда поможет кому-то

person Jotadrive    schedule 20.07.2018

Вот что я сделал (я сделал с оболочкой django, чтобы вы могли видеть, как это работает): сначала я открыл оболочку Django.

py manage.py shell

Затем вам нужно вызвать свою модель из приложения.

>>> from <app_name>.models import <model_name>
>>> querydata = <model_name>.objects.all()
>>> querydata
<QuerySet [<<mode_name>: randomdata>, <<mode_name>: randomdata2>]>

Надеюсь, я был понятен.

person Roy Martinez    schedule 31.05.2021