Django で、datetime で MySQL 検索する時にタイムゾーンがずれてうまく検索できないミス

(Comments)

けっこう何回もミスってしまうのでメモ。

settings

TIME_ZONE = 'Asia/Tokyo'
USE_TZ = True

from django.utils import timezone

now = timezone.now()

この now は、repr してみると

datetime.datetime(2017, 1, 26, 4, 4, 56, 53007, tzinfo=<UTC>)

UTC の datetime.

これはテンプレートで表示するとローカルタイムに直されるので、JST のように見える。が、見る瞬間に変換されているだけで、タイムゾーンはUTC。

これを、

now.date()

なんかで date を取り出して、MySQL の(JSTで格納されている)日付フィールドと比較すると、9時間ずれておかしなことになる。

なので、date を使いたいとか、Python コード内で strftime して使いたいとかの理由があれば、

from django.utils import timezone

now = timezone.localtime(timezone.now())

として localtime 化しておけば、

datetime.datetime(2017, 1, 26, 13, 4, 56, 53007, tzinfo=<DstTzInfo 'Asia/Tokyo' JST+9:00:00 STD>)

このように JST のタイムゾーンがついた datetime になるので使い勝手が良い。

Current rating: 4.5

Comments

Recent Tweets

  • ytyng

    ytyng @ytyng

    なおってた
    2 days, 16 hours ago

  • ytyng

    ytyng @ytyng

    vuetify って2になって、グリッドのタグ名がBootstrapと同じになったのね。v-flex と書かなくてよくなってた。良い。
    2 days, 17 hours ago

  • ytyng

    ytyng @ytyng

    YahooショッピングのAPI、応答を返さない状態じゃない? https://t.co/rYKTlr7RcU
    2 days, 19 hours ago

Recent Posts

Archive

2020
2019
2018
2017
2016
2015
2014
2013
2012
2011

Categories

Authors

Feeds

RSS / Atom