ValueError:无法将查询集用于“”:将查询集用于“”

Edu*_*rez 2 django django-models

我正在使用这些模型开展一个小项目,我正在尝试找出一种方法来获取与当前经过身份验证的用户所关注的用户关联的一组所有帖子。

但我不断得到:

无法将 QuerySet 用于“配置文件”:将 QuerySet 用于“用户”。

class Profile(models.Model):
    user = models.OneToOneField(User)
    isInstructor = models.BooleanField(default=False)
    isTutor = models.BooleanField(default=False)
    isStudent = models.BooleanField(default=False)
    isAdmin = models.BooleanField(default=False)
    following = models.ManyToManyField('self', related_name = "followers", blank=True, symmetrical=False)
    profile_image = ImageField(upload_to=get_image_path, blank=True, null=True)

class Post(models.Model):
    title = models.CharField(max_length=100)
    topic = models.CharField(max_length=50)
    description = models.CharField(max_length=1200)
    poster = models.ForeignKey(User, related_name="posts")
    likes = models.IntegerField(default=0)
    created = models.DateTimeField(auto_now_add=True)
    tags = models.ManyToManyField(Tag, blank=True, related_name="posts")

    def __str__(self):
        return self.title
Run Code Online (Sandbox Code Playgroud)

这就是一直给我错误的原因。

current_user = Profile.objects.get(user = self.request.user)
Post.objects.filter(poster__in = current_user.following.all())
Run Code Online (Sandbox Code Playgroud)

我四处搜索发现,每当你想按事物列表进行过滤时,我都必须使用 __in 运算符。但我不断收到同样的错误。任何有关解释错误含义以及我可以采取哪些措施来解决该错误的帮助将不胜感激。

zai*_*zil 6

也许尝试这样的事情,

Post.objects.filter(poster__id__in=current_user.following.all().values_list('user_id'))
Run Code Online (Sandbox Code Playgroud)