web-dev-qa-db-ja.com

Rails)で現地時間をUTCに変換します

私の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を使用して、日付/時刻の値と一緒に送信できると思います。

17
Chris Stewart

uTCのローカル

created_at.utc

uTCからローカルへ

created_at.localtime

30
andyshi

まず、タイムゾーンの設定を確認します。

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/

1
Michael Durrant