Фильтры django open_hours close_hours SyntaxError: позиционный аргумент следует за аргументом ключевого слова - PullRequest
0 голосов
/ 23 сентября 2019

Я пытался создать метод фильтра, чтобы проверить, открыто ли сейчас мое Место (модель ниже).Я определил поля open_hours и close_hours.Алгоритм выглядит довольно хорошо для меня (первые условия относятся к 21: 00-23: 00 часам, а вторые 21: 00-01: 00), но так как я новичок в объектах Q и F, я получаю syntaxError.

строка 81 Q (open_hours__lt = current_time) & Q (close_hours__gt = current_time)) ^ SyntaxError: позиционный аргумент следует за аргументом ключевого слова

class Place(models.Model):
name = models.CharField(max_length=50)
lat = models.FloatField()
lng = models.FloatField()
address = models.CharField(max_length=50)
district = models.CharField(max_length=50, choices=DISTRICTS)
link = models.URLField(help_text="www.websiteurl.pl")
open_hours = models.TimeField()
close_hours = models.TimeField()
week_day = MultiSelectField(choices=DAYS)
additionalInfo = models.CharField(max_length=500, blank=True, null=True)

def __str__(self):
    return self.name




def hasToBeOpenedRightNowFilter(self, queryset, name, value):
    now = datetime.datetime.now()                                               
    current_day = now.strftime("%A")                                        #current_day
    current_time = now.time()                                               #current_time

    queryset_day = queryset.filter(week_day__contains = current_day)        #queryset filtered after day
    query_time_1 = queryset.filter(open_hours__lt = F('close_hours'),       #queryset filtered after first condition
    Q(open_hours__lt = current_time) & Q(close_hours__gt = current_time))       
    query_time_2 = queryset.filter(open_hours__gt = F('close_hours'),       #queryset filtered after second condition
    Q(open_hours__lt = current_time) | Q(close_hours__gt = current_time))
    queryset_time = query_time_1 | query_time_2                             #merge two querysets with time conditions
    queryset_true = queryset_time & queryset_day                            #merge queryset with filter after day
    if not value:
        queryset = queryset.exclude(id__in=queryset_true.values('id'))
        return queryset
    return queryset_true

1 Ответ

0 голосов
/ 23 сентября 2019

Вы должны поместить объекты Q сначала в .filter

query_time_1 = queryset.filter(Q(open_hours__lt = current_time) & Q(close_hours__gt = current_time), open_hours__lt = F('close_hours')) 
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...