Можно ли применить фильтр диапазона дат к дате, если тип данных даты или dtype является text или str?

models-
`class RocCharge(models.Model):`
`charge_id = models.IntegerField(blank=True, null=True)`
`chname = models.CharField(max_length=100, blank=True, null=True, db_index=True)`
`date_of_creation = models.TextField(default=date.today)`

views-
`from_date = request.GET.get('fromdate')`
`to_date = request.GET.get('Todate')`
`if from_date and to_date:
    combined_data = combined_data.filter(date_of_creation__gte=from_date, date_of_creation__lte=to_date)`

моя дата создания в mysql, а также в моделях в текстовом формате, но я хочу выполнить фильтр диапазона дат от до диапазона без изменения типа данных даты, моя дата в mysql как-21-12-2019

# ...

from_date_str = request.GET.get('fromdate')
to_date_str = request.GET.get('Todate')

if from_date_str and to_date_str:
    # Convert date strings to datetime objects using a consistent format
    date_format = "%d-%m-%Y"
    from_date = datetime.strptime(from_date_str, date_format)
    to_date = datetime.strptime(to_date_str, date_format)

    # Filter based on the datetime range
    combined_data = combined_data.filter(date_of_creation__range=(from_date, to_date))

Это включает в себя преобразование строк даты из параметров запроса в объекты datetime с помощью strptime, а затем использование __range lookup для фильтрации на основе диапазона дат. Это должно работать с вашей текущей текстовой датой. Убедитесь, что формат даты правильный.

Вернуться на верх