所以我试图显示一个表中没有出现在另一个表中的项目的列表。但我不断收到诸如“无法解压不可迭代的ManyRelatedManager对象”的错误
我尝试过django过滤器的许多变体并排除,但始终存在上述错误或取决于我尝试过的其他事情的错误: 用户对象没有属性配置文件 要么 无法解压缩不可迭代的int对象
型号:
class Item(models.Model):
item_name = models.CharField(max_length=200)
def __str__(self):
return self.item_name
class Meta:
verbose_name = "Item"
verbose_name_plural = "Items"
class Profile(models.Model):
user = models.OneToOneField(User, on_delete=models.CASCADE, related_name="user")
items = models.ManyToManyField(Item)
class Meta:
verbose_name = "Profile"
verbose_name_plural = "Profiles"
观看次数:
python
@login_required
def item_view(request):
if request.method == 'GET':
user_obj = request.user.user
items = Item.objects.filter(user_obj.items)
context_dict = {'items': items}
return render(request, 'site/items.html', context_dict)
else:
return HttpResponseNotFound()
items.html:
{% for i in items%}
<li><input type="checkbox" data-pk="{{i.pk}}" name="{{i.item_name}}" value="{{i.pk}}" onchange="processChange(this)"> {{i.item_name}}<br>
</li>
{% endfor %}
目标是让items.html显示不在用户个人资料中的所有项目。我似乎尝试的所有方法似乎均不起作用,因此非常感谢您的帮助。
答案 0 :(得分:2)
替换:
items = Item.objects.filter(user_obj.items)
使用:
user_items = Items.objects.filter(profile=user_obj)
items = Items.objects.exclude(pk__in=user_items)
user_items
将包含一个查询集,其中包含与Item
中的User
相关的所有user_obj
对象。
items
将包含具有所有Item
对象的查询集,排除与User
因为filter()
需要模型中的字段,所以您遇到了错误:
filter(user='some user')
有关如何进行查询的更多信息,请访问docs
答案 1 :(得分:1)
尝试使用:
from django.shortcuts import get_list_or_404
items = get_list_or_404(Item, user=user_obj)
如果这不起作用,请尝试使用
from django.shortcuts import get_object_or_404
items = get_object_or_404(Item, user=user_obj)