не удается распаковать неитерабельный объект ModelBase в django

#django #django-models #django-views #django-templates #django-class-based-views

Вопрос:

я хочу просмотреть один элемент в списке товаров с помощью его идентификатора, но не могу добиться, чтобы я использовал cbv, он показывает мне ошибку, указанную выше, я создаю веб-сайт электронной коммерции, где я хочу загрузить только ту деталь товара, которую он нажимает из всех элементов, но не может достичь, показывая мне ошибку выше

мой models.py

 class Item(models.Model):

    categories = models.ForeignKey(Categories, on_delete=models.CASCADE, related_name='our_items')
    subcategories = models.ForeignKey(Subcategories, on_delete=models.CASCADE, related_name='products')
    can_buy = models.ForeignKey(For, on_delete=models.CASCADE, related_name='for_wearing')
    name = models.CharField(max_length=200, blank=False)
    contain_size = models.CharField(max_length=50, blank=True)
    brand_name = models.CharField(max_length=100, blank=False, default='Bagh')
    first = models.ImageField(upload_to='items', blank=False)
    second = models.ImageField(upload_to='items', blank=False)
    third = models.ImageField(upload_to='items', blank=True)
    fourth = models.ImageField(upload_to='items', blank=True)
    fifth = models.ImageField(upload_to='items', blank=True)
    item_vedio = models.FileField(upload_to='item_vedio', blank=True)
    offered_price = models.FloatField(blank=False,)
    actual_price = models.FloatField(blank=False)
    about = models.TextField(blank=False, default="about" )
    offer = models.CharField(max_length=4, blank=True)
    
    def __str__(self):
        return self.name
 

вот мой views.py

 class Product_detail(View):
    def get(self, request, products_id):
        item = Item.objects.get(Item, pk=products_id)
        category_list = Categories.objects.all()
        print(item)
        return render (request, 'products.html',{"item_list" : item, 'category_list': category_list })
 

мой urls.py

 path('<int:products_id>/details',Product_detail.as_view(),name='detail')
 

мой тег href

 <a href="{% url 'products:detail' products.id %}">
 

любое предложение будет оценено по достоинству, спасибо за ваше время

представление html, в котором отображаются все элементы

 class Product(View):
    def get(self, request, subcategory_id):
        subcategory = get_object_or_404(Subcategories, pk=subcategory_id)
        products = subcategory.products.all()
        category_list = Categories.objects.all()
        print(products)
        return render (request, 'products.html',{"subcategory_list" : products, 'category_list': category_list })
 

я думаю, тебе это нужно

добавление products.html

 <section class="col-10">
          {% for products in subcategory_list %}
          <a class="products" href="{% url 'products:detail' products_id %}">
          <div class="card col-4" style="width: 18rem; height:400px">
              <img class="img" src="{{ products.first.url }}" alt="" height="300px" width="100%" onmouseover="this.src='{{ products.second.url }}'"
              onmouseout="this.src='{{ products.first.url }}'" >
              <div class="detail">
              <h4 class="price">{{ products.offered_price|currency}}</h4>
              <h5>{{products.name}} <br> <span>{{ products.brand_name}}</span> </h5>
              <p class="rate">Rate: 4.5<i class="fas fa-star"></i></p>
              <h6>Size:<span> {{products.contain_size}}</span> </h6>
              </div>
            </div>
          </a>
            {% endfor %} 
          </div>  
        </section>
 

url-адрес моих модулей

 path('<int:subcategory_id>/products/',Product.as_view(),name='product'),
 

добавление обратной трассировки

 Environment:


Request Method: GET
Request URL: http://localhost:8000/1/details

Django Version: 3.2.5
Python Version: 3.8.5
Installed Applications:
['django.contrib.admin',
 'django.contrib.auth',
 'django.contrib.contenttypes',
 'django.contrib.sessions',
 'django.contrib.messages',
 'django.contrib.staticfiles',
 'crispy_forms',
 'accounts',
 'products']
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:UsersmithleshDesktopcoolbuy 2.0libsite-packagesdjangocorehandlersexception.py", line 47, in inner
    response = get_response(request)
  File "C:UsersmithleshDesktopcoolbuy 2.0libsite-packagesdjangocorehandlersbase.py", line 181, in _get_response
    response = wrapped_callback(request, *callback_args, **callback_kwargs)
  File "C:UsersmithleshDesktopcoolbuy 2.0libsite-packagesdjangoviewsgenericbase.py", line 70, in view
    return self.dispatch(request, *args, **kwargs)
  File "C:UsersmithleshDesktopcoolbuy 2.0libsite-packagesdjangoviewsgenericbase.py", line 98, in dispatch
    return handler(request, *args, **kwargs)
  File "C:UsersmithleshDesktopcoolbuy 2.0coolbuyproductsviews.py", line 29, in get
    item = Item.objects.get(Item, pk=item_id)
  File "C:UsersmithleshDesktopcoolbuy 2.0libsite-packagesdjangodbmodelsmanager.py", line 85, in manager_method
    return getattr(self.get_queryset(), name)(*args, **kwargs)
  File "C:UsersmithleshDesktopcoolbuy 2.0libsite-packagesdjangodbmodelsquery.py", line 424, in get
    clone = self._chain() if self.query.combinator else self.filter(*args, **kwargs)
  File "C:UsersmithleshDesktopcoolbuy 2.0libsite-packagesdjangodbmodelsquery.py", line 941, in filter
    return self._filter_or_exclude(False, args, kwargs)
  File "C:UsersmithleshDesktopcoolbuy 2.0libsite-packagesdjangodbmodelsquery.py", line 961, in _filter_or_exclude
    clone._filter_or_exclude_inplace(negate, args, kwargs)
  File "C:UsersmithleshDesktopcoolbuy 2.0libsite-packagesdjangodbmodelsquery.py", line 968, in _filter_or_exclude_inplace
    self._query.add_q(Q(*args, **kwargs))
  File "C:UsersmithleshDesktopcoolbuy 2.0libsite-packagesdjangodbmodelssqlquery.py", line 1393, in add_q
    clause, _ = self._add_q(q_object, self.used_aliases)
  File "C:UsersmithleshDesktopcoolbuy 2.0libsite-packagesdjangodbmodelssqlquery.py", line 1412, in _add_q
    child_clause, needed_inner = self.build_filter(
  File "C:UsersmithleshDesktopcoolbuy 2.0libsite-packagesdjangodbmodelssqlquery.py", line 1283, in build_filter
    arg, value = filter_expr

Exception Type: TypeError at /1/details
Exception Value: cannot unpack non-iterable ModelBase object
 

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

1. Можете ли вы поделиться всей обратной связью? Кроме "item_list" : item того , элемент здесь-это всего лишь один экземпляр, вы используете его в качестве списка в своем шаблоне?

2. @bdbd я только что добавил, на самом деле я связал свою подкатегорию с элементом, поэтому, когда я нажимаю на любую конкретную подкатегорию, она products.html откроется список товаров, связанных с этой подкатегорией, поэтому я хочу, чтобы любой щелчок по любому элементу этой подкатегории, а затем открывался products.detail, и отображалось только содержимое, связанное с этим элементом

3. @bdbd извините, что была опечатка, используя его в качестве списка, я хочу, чтобы на этой странице была только информация об этом элементе, а не список

4. Обратная связь точно сообщит вам о проблеме в этой строке: Item.objects.get(Item, pk=item_id) . Сначала попробуйте это исправить

5. я заставил это сработать, кстати, спасибо тебе

Ответ №1:

Проблема с вашими URL-адресами href

Вы можете попробовать вот так:

 <a href="{% url 'products:detail' products_id=products.id %}">
 

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

1. добавлен мой вид продуктов, в котором отображаются все товары