MU
Maciej Urmański11 декабря 2019 г. 17:27

Count user objects e.g posts

python, Django

Hi, I try to get numbers of user post.

I have model Embed and try to count how many user add this embeds.

My model:

class Embed(models.Model):
    url = models.URLField(max_length=255)
    title = models.CharField(max_length=255, verbose_name='Tytuł')
    description = HTMLField(verbose_name='Opis', blank=True, null=True)
    type = models.CharField(blank=True, max_length=200)
    thumbnail_url = models.URLField(max_length=255, blank=True, null=True)
    image = models.ImageField(upload_to='recipes', blank=True)
    html = models.TextField()
    votes = GenericRelation(LikeDislike, related_query_name='embedlikes')
    added_by = models.ForeignKey(User, on_delete=models.CASCADE)
    created_at = models.DateTimeField(auto_now_add=True)
    category = TreeManyToManyField(RecipeCategory, blank=True, null=True, related_name='embeds', verbose_name='Kategoria')
    slug = AutoSlugField(populate_from='title', unique=True)

Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Вам это нравится? Поделитесь в социальных сетях!

7
Evgenii Legotckoi
  • 11 декабря 2019 г. 17:52

Hello,

Try this

from django.db.models import Count
embeds = Embed.objects.annotate(total=Count('added_by'))
embeds[0].total
    MU
    • 11 декабря 2019 г. 18:52
    • (ред.)

    Hmm this count every recipes. Not only one user.

    I try something like that from stackoverflow:

    def recipedetail(request, slug):
        recipe = get_object_or_404(Embed, slug=slug)
        num_embed = recipe.objects.filter(added_by=added_by).count()
        return render(request, 'recipes/detail.html', {'recipe': recipe,
                                                        'num_embed': num_embed}
    

    But then error appear:

    Manager isn't accessible via Embed instances

    I have this from there: https://stackoverflow.com/questions/50393455/count-the-number-of-posts-by-a-user-django

      Evgenii Legotckoi
      • 11 декабря 2019 г. 19:07
      • (ред.)

      May be, because, you don`t have field "author" in your model... ?

      And in this code you get object of model

      recipe = get_object_or_404(Embed, slug=slug)
      

      Therefore you cannot use objects in this row

      num_embed = recipe.objects.filter(author=author).count()
      

      Because of objects can be used only in this situation

      Embed.objects.all() # only for model class, not for instance
      

      And I don`t see author instance in your code.

      You can write something else like this

      def recipedetail(request, slug):
          recipe = get_object_or_404(Embed, slug=slug)
          # missed author instance, need to add code for getting author instance
          num_embed = Embed.objects.filter(added_by=author).count()
          return render(request, 'recipes/detail.html', {'recipe': recipe,
                                                          'num_embed': num_embed}
      

      But you should get author instance from anywhere, for example request.user

        MU
        • 11 декабря 2019 г. 19:08

        Yeah I edit my answer and change to added_by. But still this don't work.

          Evgenii Legotckoi
          • 11 декабря 2019 г. 19:11
          • (ред.)

          added_by must be some author instance, some object. You should get this object from anywhere. In your code you don`t make any actions for getting author instance.

          Ok, try this

          def recipedetail(request, slug):
              recipe = get_object_or_404(Embed, slug=slug)
              num_embed = recipe.objects.filter(added_by=request.user).count()
              return render(request, 'recipes/detail.html', {'recipe': recipe,
                                                              'num_embed': num_embed}
          
            Evgenii Legotckoi
            • 11 декабря 2019 г. 19:14

            or this

            def recipedetail(request, slug):
                recipe = get_object_or_404(Embed, slug=slug)
                num_embed = recipe.objects.filter(added_by=recipe.added_by).count()
                return render(request, 'recipes/detail.html', {'recipe': recipe,
                                                                'num_embed': num_embed}
            
              MU
              • 11 декабря 2019 г. 19:27
              • Ответ был помечен как решение.

              Thank you! Now works, and this is solution.

              num_embed = Embed.objects.filter(added_by=recipe.added_by).count()
              

                Комментарии

                Только авторизованные пользователи могут публиковать комментарии.
                Пожалуйста, авторизуйтесь или зарегистрируйтесь
                Ua

                Qt - Тест 001. Сигналы и слоты

                • Результат:84баллов,
                • Очки рейтинга4
                Ua

                Qt - Тест 001. Сигналы и слоты

                • Результат:42баллов,
                • Очки рейтинга-8
                ОК

                Qt - Тест 001. Сигналы и слоты

                • Результат:47баллов,
                • Очки рейтинга-6
                Последние комментарии
                ИМ
                Игорь Максимов22 ноября 2024 г. 21:51
                Django - Урок 017. Кастомизированная страница авторизации на Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
                Evgenii Legotckoi
                Evgenii Legotckoi31 октября 2024 г. 23:37
                Django - Урок 064. Как написать расширение для Python Markdown Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
                A
                ALO1ZE19 октября 2024 г. 17:19
                Читалка fb3-файлов на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
                ИМ
                Игорь Максимов5 октября 2024 г. 16:51
                Django - Урок 064. Как написать расширение для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                d
                dblas55 июля 2024 г. 20:02
                QML - Урок 016. База данных SQLite и работа с ней в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                Сейчас обсуждают на форуме
                f
                firstlunoxod15 февраля 2025 г. 13:46
                Рисование на QGraphicsScene при зажатой кнопке мыши Подскажите, пожалуйста! Как данный класс можно дополнить, чтобы созданные объекты можно было перемещать мышкой по сцене?
                Дмитрий
                Дмитрий3 февраля 2025 г. 16:24
                Создание deb-пакета. Как создать ярлык на рабочем столе после установки собственного deb-пакета? Всем привет. Сделал свой deb-пакет с программой. Всё устанавливается и работает. Ставлю по пути /usr/bin/my_application. Как для пользователя при установке пакета сразу создать ярлык на раб…
                NW
                Nayo Wai30 января 2025 г. 19:22
                не запускается компьютер!!! Не запускается компьютер (точнее работает блок , но сам монитор вообще жесть)В общем я ничего с интернета не скачивала в последнее время. На компе никаких левых пр…
                n
                nkly3 января 2025 г. 12:52
                Нужно запретить перемещение только некоторых итемов, остальные перемещать можно. Вопрос решен. Узнать QModelIndex элемента на который мы перетаскиваем другой элемент, можно с помощью функции indexAt(event->position().toPoint()) представления QTreeViev вызываемой в переопр…
                M
                Marsel17 августа 2023 г. 0:26
                OAuth2.0 через VK, получение email Спасибо большое за помощь и простите за то что отнял время своей невнимательностью.

                Следите за нами в социальных сетях