Django 时区设置为USE_TZ = False 查询时间出错

问题

    USE_TZ = False后,django orm  查询时间报错:MySQL backend does not support timezone-aware datetimes when USE_TZ is False.

解决: 查询时间前,做替换

    

import pytz
from django.utils import timezone


USE_TZ = False
if USE_TZ is True:
    tzinfo_ = pytz.utc
else:
    tzinfo_ = None

start_time_str = '2019-11-01T16:00:00.000Z'
end_time_str = '2019-11-02T16:00:00.000Z'
# 时间做时区转换
start_time = timezone.datetime.strptime(start_time_str, '%Y-%m-%dT%H:%M:%S.%fZ').replace(tzinfo=tzinfo_)
end_time = timezone.datetime.strptime(end_time_str, '%Y-%m-%dT%H:%M:%S.%fZ').replace( tzinfo=tzinfo_)
# 查询mysql数据库
query_set = TestModel.objects.filter(create_time__range=(start_time, end_time))

 

### Django项目国际化与时区设置 为了正确配置Django项目的国际化和时区功能,需要合理调整`settings.py`中的多个参数。以下是关于这些参数的具体说明以及如何实现多语言支持。 #### 参数详解 1. **LANGUAGE_CODE**: 定义默认的语言环境。例如,`zh-hans`表示简体中文[^1]。 2. **TIME_ZONE**: 配置服务器使用的时区,默认为`UTC`。如果希望使用中国标准时间,则应将其设为`Asia/Shanghai`[^3]。 3. **USE_I18N**: 启用国际化的开关。当其值为`True`时,Django会加载相应的翻译文件[^2]。 4. **USE_L10N**: 控制本地化格式的支持状态。启用后,日期、时间和数字将以当前区域的格式显示。 5. **USE_TZ**: 是否启用时区感知的时间处理机制。建议保持为`True`以避免因不同地区用户的访问而引发的时间错误。 #### 示例代码 以下是一个完整的`settings.py`配置示例: ```python import os # 语言编码 LANGUAGE_CODE = 'zh-hans' # 时区设置 TIME_ZONE = 'Asia/Shanghai' # 开启国际化 USE_I18N = True # 开启本地化 USE_L10N = True # 使用时区感知的时间USE_TZ = True # 支持多种语言 LANGUAGES = ( ('en', _('English')), ('zh-hans', _('Simplified Chinese')), ) # 存放翻译文件的位置 LOCALE_PATHS = [ os.path.join(BASE_DIR, 'locale'), ] # REST Framework 时间格式自定义 REST_FRAMEWORK = { 'DATETIME_FORMAT': '%Y-%m-%d %H:%M:%S', } ``` #### URL配置 为了让应用支持多语言切换,需通过URL路由来动态改变语言环境。可以通过`django.conf.urls.i18n`模块完成此操作[^4]。 ```python from django.contrib import admin from django.urls import path, include from django.conf.urls.i18n import i18n_patterns urlpatterns = [ # 添加语言切换接口 path('i18n/', include('django.conf.urls.i18n')), ] # 将管理后台和其他视图加入到多语言模式下 urlpatterns += i18n_patterns( path('admin/', admin.site.urls), ) ``` #### 注意事项 - 如果开启了`USE_TZ=True`,但在某些场景下查询结果为空,可能是因为数据库存储的是未经过时区转换的数据。此时需要确认数据写入时是否已进行了正确的时区标记。 - `LOCALE_PATHS`路径必须存在并包含`.po`和`.mo`文件,否则无法正常加载翻译内容。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值