Вычислить разницу во времени на основе часа между текущим временем и временем последнего обновления

#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