私のMySQLデータベースでは、updated_atフィールドはUTCとして保存されています。先週、レコードは東部標準時午後7時に入力され、updated_at値は「2012-08-0123:00:00」です。データベースのupdated_atフィールドと比較できるUTCにWebクライアントの現地時間を変換しようとしています。
例として、「08/01/2012 07:00 pm」を「2012-08-0123:00:00」(EDTにいることを考慮)に変換したいのですが、タイムゾーンがありません。変換の側面。 「7:00 pm」は現地時間であり、どのタイムゾーンからでもかまいません。私の現在のコード:
Ruby-1.9.2-head :015 > from_date = DateTime.strptime('08/01/2012 07:00 pm', '%m/%d/%Y %H:%M %p')
=> Wed, 01 Aug 2012 19:00:00 +0000
Ruby-1.9.2-head :016 > from_date = Time.zone.parse(from_date.to_s).utc
=> 2012-08-01 19:00:00 UTC
何かご意見は?
編集:また、strptime呼び出しで「%Z」を使用することもできますが、これは、値にタイムゾーンがあることを前提としていますが、現在は使用していません。 Javascriptを使用して、日付/時刻の値と一緒に送信できると思います。
uTCのローカル
created_at.utc
uTCからローカルへ
created_at.localtime
まず、タイムゾーンの設定を確認します。
Environment.rb(Rails 2)またはapplication.rb(Rails 3)ファイルでは、次のコマンドでデフォルトのタイムゾーンを設定できます:config.time_zone = 'Eastern Daylight Time (EDT)'
次に、この投稿を見て、ニーズを満たすための情報とガイダンス、およびヒントを探します。
http://databasically.com/2010/10/22/what-time-is-it-or-handling-timezones-in-Rails/