关于Django的TIME_ZONE时区问题的若干总结

本文介绍了Django中TIME_ZONE和USE_TZ参数的作用及配置方法,并解释了如何利用make_aware和make_naive函数进行时区转换。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在Django1.6的settings.py文件中有TIME_ZONE和USE_TZ两个参数来描述时区的设置。

TIME_ZONE:用于存放本地时区信息,默认值为UTC,意思为采用国际标准时间“格林尼治时间”。中国处于东八区,官方文档上有两个取值“Asia/Shanghai”和“Asia/Chongqing”(没有北京).

USE_TZ:用于控制是否使用UTC时间(True and False)。如果设置为False,则使用本地时间。

为了保证世界各地时间统一性,可以在数据库中使用UTC时间,根据需求转换成相应时区时间。


在timezone模块里有两个函数:

[python]  view plain  copy
  1. <span style="font-size:18px;">def make_aware(value, timezone):  
  2.     """ 
  3.     Makes a naive datetime.datetime in a given time zone aware. 
  4.     """  
  5.     if hasattr(timezone, 'localize'):  
  6.         # available for pytz time zones  
  7.         return timezone.localize(value, is_dst=None)  
  8.     else:  
  9.         # may be wrong around DST changes  
  10.         return value.replace(tzinfo=timezone)</span>  
[python]  view plain  copy
  1. <span style="font-size:18px;">def make_naive(value, timezone):  
  2.     """ 
  3.     Makes an aware datetime.datetime naive in a given time zone. 
  4.     """  
  5.     value = value.astimezone(timezone)  
  6.     if hasattr(timezone, 'normalize'):  
  7.         # available for pytz time zones  
  8.         value = timezone.normalize(value)  
  9.     return value.replace(tzinfo=None)</span>  


这里的naive表示是否已知时区,即tzinfo是否为None,make_aware函数根据指定的时区将模糊时间转换成相应时区的时间,make_naive正好相反。



如何修改为当地时区:

# LANGUAGE_CODE = 'en-us'
LANGUAGE_CODE = 'zh-Hans'


# TIME_ZONE = 'UTC'
TIME_ZONE = 'Asia/Shanghai'

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值