Как мы можем случайным образом получить более двух пользователей из базы данных в Django?

#python #django #django-models #django-rest-framework #django-forms

#python #django #django-модели #django-rest-framework #django-forms

Вопрос:

Ну, я создаю профиль каждого нового пользователя с помощью сигналов и пытаюсь добавить несколько подписчиков по умолчанию в новый профиль пользователя. Я пытаюсь использовать следующий код, и это на самом деле неплохо, но не совсем то, что я хочу сделать. Хорошо со следующим кодом. первые 2 пользователя с pk = 1, pk = 2 становятся подписчиками по умолчанию для каждого нового профиля. Хотел бы я дать несколько случайных пользователей в качестве подписчиков каждому новому пользователю.

Например: первый пользователь создал новую учетную запись и получил двух пользователей, следующих по умолчанию с pk = 1, pk = 2, затем второй пользователь создал новую учетную запись и получил двух пользователей, следующих по умолчанию с другим первичным ключом, таким как pk = 2, pk = 4.

Код: со следующим кодом каждый новый пользователь получает тех же двух пользователей 2 с pk = 1, pk = 2, я этого не хочу. Как можно сделать то, что я объяснил на примере. Пожалуйста, помогите, потому что мне нужно в этом случае. Я буду вам очень благодарен. если требуется больше деталей или кода, скажите мне. Я поделюсь этим с вами.

 def create_profile(sender, created,instance,**kwargs):
    if created:
        userprofile = UserProfile.objects.create(user=instance)
        default_user_profile = UserProfile.objects.get_or_create(user__pk=1)[0]
        default_user_profile.follower.add(instance)
        userprofile.follower.add(default_user_profile.user)
        userprofile.follower.add(2)
  

Другая ошибка.

     Environment:


Request Method: POST
Request URL: http://127.0.0.1:8000/admin/auth/user/add/

Django Version: 3.0.3
Python Version: 3.8.3
Installed Applications:
['django.contrib.admin',
 'django.contrib.auth',
 'django.contrib.contenttypes',
 'django.contrib.sessions',
 'django.contrib.messages',
 'django.contrib.staticfiles',
 'bootstrap3',
 'accounts',
 'posts',
 'profiles']
Installed Middleware:
['django.middleware.security.SecurityMiddleware',
 'django.contrib.sessions.middleware.SessionMiddleware',
 'django.middleware.common.CommonMiddleware',
 'django.middleware.csrf.CsrfViewMiddleware',
 'django.contrib.auth.middleware.AuthenticationMiddleware',
 'django.contrib.messages.middleware.MessageMiddleware',
 'django.middleware.clickjacking.XFrameOptionsMiddleware']



Traceback (most recent call last):
  File "C:UsersAHMEDanaconda3libsite-packagesdjangocorehandlersexception.py", line 34, in inner
    response = get_response(request)
  File "C:UsersAHMEDanaconda3libsite-packagesdjangocorehandlersbase.py", line 115, in _get_response
    response = self.process_exception_by_middleware(e, request)
  File "C:UsersAHMEDanaconda3libsite-packagesdjangocorehandlersbase.py", line 113, in _get_response
    response = wrapped_callback(request, *callback_args, **callback_kwargs)
  File "C:UsersAHMEDanaconda3libsite-packagesdjangocontribadminoptions.py", line 607, in wrapper
    return self.admin_site.admin_view(view)(*args, **kwargs)
  File "C:UsersAHMEDanaconda3libsite-packagesdjangoutilsdecorators.py", line 130, in _wrapped_view
    response = view_func(request, *args, **kwargs)
  File "C:UsersAHMEDanaconda3libsite-packagesdjangoviewsdecoratorscache.py", line 44, in _wrapped_view_func
    response = view_func(request, *args, **kwargs)
  File "C:UsersAHMEDanaconda3libsite-packagesdjangocontribadminsites.py", line 231, in inner
    return view(request, *args, **kwargs)
  File "C:UsersAHMEDanaconda3libsite-packagesdjangoutilsdecorators.py", line 43, in _wrapper
    return bound_method(*args, **kwargs)
  File "C:UsersAHMEDanaconda3libsite-packagesdjangoviewsdecoratorsdebug.py", line 76, in sensitive_post_parameters_wrapper
    return view(request, *args, **kwargs)
  File "C:UsersAHMEDanaconda3libsite-packagesdjangoutilsdecorators.py", line 43, in _wrapper
    return bound_method(*args, **kwargs)
  File "C:UsersAHMEDanaconda3libsite-packagesdjangoutilsdecorators.py", line 130, in _wrapped_view
    response = view_func(request, *args, **kwargs)
  File "C:UsersAHMEDanaconda3libsite-packagesdjangocontribauthadmin.py", line 99, in add_view
    return self._add_view(request, form_url, extra_context)
  File "C:UsersAHMEDanaconda3libsite-packagesdjangocontribauthadmin.py", line 126, in _add_view
    return super().add_view(request, form_url, extra_context)
  File "C:UsersAHMEDanaconda3libsite-packagesdjangocontribadminoptions.py", line 1638, in add_view
    return self.changeform_view(request, None, form_url, extra_context)
  File "C:UsersAHMEDanaconda3libsite-packagesdjangoutilsdecorators.py", line 43, in _wrapper
    return bound_method(*args, **kwargs)
  File "C:UsersAHMEDanaconda3libsite-packagesdjangoutilsdecorators.py", line 130, in _wrapped_view
    response = view_func(request, *args, **kwargs)
  File "C:UsersAHMEDanaconda3libsite-packagesdjangocontribadminoptions.py", line 1522, in changeform_view
    return self._changeform_view(request, object_id, form_url, extra_context)
  File "C:UsersAHMEDanaconda3libsite-packagesdjangocontribadminoptions.py", line 1565, in _changeform_view
    self.save_model(request, new_object, form, not add)
  File "C:UsersAHMEDanaconda3libsite-packagesdjangocontribadminoptions.py", line 1081, in save_model
    obj.save()
  File "C:UsersAHMEDanaconda3libsite-packagesdjangocontribauthbase_user.py", line 66, in save
    super().save(*args, **kwargs)
  File "C:UsersAHMEDanaconda3libsite-packagesdjangodbmodelsbase.py", line 745, in save
    self.save_base(using=using, force_insert=force_insert,
  File "C:UsersAHMEDanaconda3libsite-packagesdjangodbmodelsbase.py", line 793, in save_base
    post_save.send(
  File "C:UsersAHMEDanaconda3libsite-packagesdjangodispatchdispatcher.py", line 173, in send
    return [
  File "C:UsersAHMEDanaconda3libsite-packagesdjangodispatchdispatcher.py", line 174, in <listcomp>
    (receiver, receiver(signal=self, sender=sender, **named))
  File "C:UsersAHMEDgrapPubgrabpublicprofilesmodels.py", line 48, in create_profile
    userprofile.follower.add(f1, f2)
  File "C:UsersAHMEDanaconda3libsite-packagesdjangodbmodelsfieldsrelated_descriptors.py", line 944, in add
    self._add_items(
  File "C:UsersAHMEDanaconda3libsite-packagesdjangodbmodelsfieldsrelated_descriptors.py", line 1119, in _add_items
    target_ids = self._get_target_ids(target_field_name, objs)
  File "C:UsersAHMEDanaconda3libsite-packagesdjangodbmodelsfieldsrelated_descriptors.py", line 1061, in _get_target_ids
    raise TypeError(

Exception Type: TypeError at /admin/auth/user/add/
Exception Value: 'User' instance expected, got <UserProfile: onwer UserProfile>
  

Ответ №1:

Мы можем получить два случайных UserProfile объекта с:

 UserProfile.objects.order_by('?')[:2]  

итак, мы можем добавить их с помощью

 def create_profile(sender, created,instance,**kwargs):
    if created:
        following = list(UserProfile.objects.order_by('?')[:2])
        userprofile = UserProfile.objects.create(user=instance)
        userprofile.follower.add(*following)  

но если число UserProfile s увеличится, это займет значительное время. Он сгенерирует случайное число для каждого UserProfile , а затем получит два с наибольшим числом, что может быть не идеально.

Мы можем использовать более псевдослучайный подход, который менее случайный, но более эффективный:

 from random import sample

def create_profile(sender, created,instance,**kwargs):
    if created:
        pk_range = UserProfile.objects.count()
        k1, k2 = sample(range(pk_range), 2)
        f1 = UserProfile.objects.all()[k1]
        f2 = UserProfile.objects.all()[k2]
        userprofile = UserProfile.objects.create(user=instance)
        userprofile.follower.add(f1.user_id, f2.user_id)  

Это сработает, если, конечно, уже есть как минимум два UserProfile s. Таким образом, мы можем защититься от условия, когда еще нет двух UserProfile s с:

 from random import sample

def create_profile(sender, created,instance,**kwargs):
    if created:
        pk_range = UserProfile.objects.count()
        if pk_range > 1:
            k1, k2 = sample(range(pk_range), 2)
            f1 = UserProfile.objects.all()[k1]
            f2 = UserProfile.objects.all()[k2]
            userprofile = UserProfile.objects.create(user=instance)
            userprofile.follower.add(f1.user_id, f2.user_id)  

Комментарии:

1. Умм! я вставляю этот код, и ‘default_user_profile’ не определен, а также в (pk__gte = k) , k также не определено.

2. @FlashMaddy: разве вы не должны добавить его в userprofile ? В вашем коде это выглядит так, как будто вы добавляете созданный UserProfile к последователям default_user_profile , а 2 также. Итак, последняя строка в вашем сигнале добавляет первого подписчика ко второму. В любом случае, обновлено.

3. Что ж, теперь, когда я пытаюсь зарегистрировать нового пользователя, он показывает мне эту ошибку: TypeError в /admin/auth/user/add / неподдерживаемые типы операндов для : ‘UserProfile’ и ‘int’

4. @FlashMaddy: вам нужно импортировать его from random import sample .,

5. @FlashMaddy: значит follower , это ManyToManyField to User , а не UserProfile ? Тогда это .add(f1.user_id, f2.user_id)

Ответ №2:

 import random

users_scope = User.objects.all().exclude(pk=my_user_pk)

user_count = users_scope.count()
user_index_1, user_index_2 = random.sample(range(user_count - 1), 2)

follower1 = users_scope[user_index_1]
follower2 = users_scope[user_index_2]