#python #django
#python #django
Вопрос:
Я хочу идентифицировать объекты, которые обновлялись в течение 24 часов.
моя модель
class Product(models.Model):
category = models.ForeignKey(Category, on_delete=models.CASCADE, related_name='products')
name = models.CharField(max_length=200)
slug = models.SlugField(max_length=200, unique=True)
image = models.ImageField(upload_to='products/%Y/%m/%d/')
description = models.TextField()
price = models.DecimalField(max_digits=10, decimal_places=2)
available = models.BooleanField(default=True)
created = models.DateTimeField(auto_now_add=True)
updated = models.DateTimeField(auto_now=True)
мое мнение:
def home(request):
products = Product.objects.filter(available=True)
return render(request, 'shop_app/home.html', {'products': products})
Ответ №1:
Я предполагаю, что вы пытаетесь получить результат, значения updated
которого для CurrentDateTime - 24 hours
поля 1 day
равны.
чего можно добиться, добавив еще один параметр в тег фильтра, т.е. updated >= valid_dt
Где valid_dt
- действительное время даты (текущее время даты - 1 день), рассчитанное с использованием timedelta
from datetime import datetime, timedelta
def home(request):
valid_dt = datetime.now() - timedelta(days=1)
products = Product.objects.filter(available=True, updated__gte=valid_dt)
return render(request, 'shop_app/home.html', {'products': products})
ПРИМЕЧАНИЕ: Если вы хотите изменить время, которое не выражается в день / месяц / год, вы можете использовать relativedelta