我想从django中的数据库中仅获取特定类别的产品(女性)产品

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了我想从django中的数据库中仅获取特定类别的产品(女性)产品相关的知识,希望对你有一定的参考价值。

 {% regroup products by categories as products_by_category %}
    {% for c in products_by_category %}
       <h1>{{c.grouper}}</h1>
       <ul>
        {% for p in c.list %}
            <li>{{p.name}}</li>
            <li> <img src="{{ MEDIA_URL }}{{ p.image.url }}" alt="IMG-PRODUCT" height="290" width="190"></li>
            <li>{{ p.price }}</li>
        {% endfor %}
       </ul>
    {% endfor %}

这是我的Views.py

def product_list_women(request, category_slug=None):
    category = None
    categories = Category.objects.filter(name='women', slug='women')
    products = Product.objects.filter(available=True)
    if category_slug:
        category = get_object_or_404(Category, slug=category_slug)
        products = products.filter(category=categories)
    return render(request, 'product_women.html',{'category': category,'categories':categories,'products':products})

这是我的models.py文件

class Category(models.Model):
    name = models.CharField(max_length=150, db_index=True)
    slug = models.SlugField(max_length=150, unique=True ,db_index=True)
    created_at = models.DateTimeField(auto_now_add=True)
    updated_at = models.DateTimeField(auto_now=True)

    class Meta:
        ordering = ('name', )
        verbose_name = 'category'
        verbose_name_plural = 'categories'

    def __str__(self):
        return self.name

    def get_absolute_url(self):
        return reverse('demo:category', args=[self.slug])

    def get_products(self):
        return Product.objects.filter(category=self)


class Product(models.Model):
    category = models.ForeignKey(Category, related_name='products', on_delete=models.CASCADE)
    name = models.CharField(max_length=100, db_index=True)
    slug = models.SlugField(max_length=100, db_index=True)
    description = models.TextField(blank=True)
    price = models.DecimalField(max_digits=10, decimal_places=2)
    available = models.BooleanField(default=True)
    stock = models.PositiveIntegerField()
    created_at = models.DateTimeField(auto_now_add=True)
    updated_at = models.DateTimeField(auto_now=True)
    image = models.ImageField(upload_to='products/%Y/%m/%d', blank=True)

    class Meta:
        ordering = ('name', )
        index_together = (('id', 'slug'),)

    def __str__(self):
        return self.name

    def get_absolute_url(self):
        return reverse('demo:product_detail', args=[self.id, self.slug])

我想仅列出女性产品而不是所有类别的产品类别。我想制作显示产品的页面,当我点击该类别时。此代码显示所有产品类别明智。我怎么能这样做?

答案

Django's Many-to-one relationship Documentation说:

相关经理也支持字段查找。 API会根据您的需要自动跟踪关系。使用双下划线来分隔关系。这可以根据需要深入多个级别。没有限制。

因此,您可以这样做:

products = Product.objects.filter(available=True, category__name='women')

以上是关于我想从django中的数据库中仅获取特定类别的产品(女性)产品的主要内容,如果未能解决你的问题,请参考以下文章

如何在 django 中仅获取表的特定列? [复制]

ajax 上的 JS 警报添加到购物车以获取 Woocommerce 中的特定产品类别计数

从 Woocommerce 相关产品中排除特定产品类别

如何计算 Django 模板中的产品?

如何在 django rest 框架中仅使用特定变体对象将项目添加到愿望清单?

如何在张量流对象检测中仅检测特定类别的对象