Django 1.9 在列表中查找属性等于某个值的对象

Posted

技术标签:

【中文标题】Django 1.9 在列表中查找属性等于某个值的对象【英文标题】:Django 1.9 Find object in list that has attribute equal to some value 【发布时间】:2016-05-01 03:03:48 【问题描述】:

我想知道如何查询属性等于某个给定值的所有餐厅,以及交付区域属性列表中的其他给定值。 这是我的代码的外观:

models.py

class Restaurant(models.Model):
    name = models.CharField(max_length=120)
    delivery_zones = models.ManyToManyField('DeliveryZone', default=None)
    service_type = models.CharField(max_length=25, choices=settings.SERVICE_TYPE_CHOICES, default='DELIVERY')
    is_active = models.BooleanField(default=False)

class DeliveryZones(models.Model):
    zone = models.CharField(max_length=25, default=None)
    is_active = models.BooleanField(default=False)

views.py:

restaurants = get_list_404(
    Restaurant, is_active=True,
    service_type='SOME_GIVEN_SERVICE_TYPE_NAME',
    delivery_zones__icontains='SOME_GIVEN_ZONE_NAME'
)

【问题讨论】:

【参考方案1】:

听起来您正在寻找的是__in 查找。另外,它是get_list_or_404,而不是get_list_404

试试:

zones = DeliveryZones.objects.filter(zone='SOME_NAME', is_active=True)
restaurants = get_list_or_404(
    Restaurant, is_active=True,
    service_type='SOME_GIVEN_SERVICE_TYPE_NAME',
    delivery_zones__in=zones
)

【讨论】:

太棒了!如果这解决了问题,请务必按我答案左侧的“检查”标记,以便任何需要帮助的人都知道答案【参考方案2】:

您可以使用lookup that spans a relationship 在单个查询中执行此操作,这意味着单个数据库命中:

restaurants = get_list_or_404(
    Restaurant, is_active=True,
    service_type='SOME_GIVEN_SERVICE_TYPE_NAME',
    delivery_zones__name='SOME_GIVEN_ZONE_NAME'
)

这会更有效率,尤其是在DeliveryZones 的可能列表很长的情况下。

【讨论】:

以上是关于Django 1.9 在列表中查找属性等于某个值的对象的主要内容,如果未能解决你的问题,请参考以下文章

MongoDB查找所有数组元素都等于某个值的文档

在 Python 的列表中查找某个值的第一个和最后一个索引

查找列表中某个值的位置

查找列表中哪个数字总和等于某个数字的算法

Haskell:返回与其前任的绝对差等于或小于某个值的列表项

查找是不是在列表中找到具有特定属性值的元素