在
数据库中插入的时间是默认的UTC,而不是基于时区的时间。我不明白为什么会发生这种情况,尽管我在查询中特别指定了我要插入的时间。
在我的模型中,我有
class leave(models.Model):
date_created = models.DateTimeField(auto_now_add=True)
在我的设置中,我有
TIME_ZONE = 'UTC'
USE_I18N = True
USE_L10N = True
USE_TZ = True
在我看来,我是根据员工国家/地区设置时区的
if employees.objects.get(emp_id=request.user.username).emp_loc == 'IND':
tzone=pytz.timezone('Asia/Calcutta')
elif employees.objects.get(emp_id=request.user.username).emp_loc == 'MLA':
tzone=pytz.timezone('Asia/Manila')
elif employees.objects.get(emp_id=request.user.username).emp_loc == 'MPLS':
tzone=pytz.timezone('CST6CDT')
然后我正在创建休假并根据国家/地区更新时区
new_leave = leave.objects.create(employee=employees.objects.get(emp_id = userid.emp_id), start_date=sdt, end_date=edt, ltype=ltyp, message=des,date_created=datetime.now(tzone))
new_leave.save()
提前谢谢。
您可以创建一个处理日期和时间转换的中间件,进口派茨
from django.utils import timezone
from django.utils.deprecation import MiddlewareMixin
class TimezoneMiddleware(MiddlewareMixin):
def process_request(self, request):
tzname = request.session.get('django_timezone')
if tzname:
timezone.activate(pytz.timezone(tzname))
else:
timezone.deactivate()
然后,您可以使用前面指示的条件轻松创建视图。最好按照 Kevin 的建议阅读文档。