我正在尝试解析一个访问我的api的字符串。传入的字符串是
"2014-03-19T04:00:00.000Z"
我需要以下格式的数据库sql才能工作:
"2014-03-19 00:00:00 -0400"
现在,我想出的解决办法是
Time.zone.parse("2014-03-19T04:00:00.000Z").in_time_zone('America/New_York').to_s
对我来说,这是一种不雅的解决方案,我觉得应该有一种更动态的方法来处理事情,而不需要指定时区名称(默认情况下应该是本地的)。我只想转换字符串的格式,因为它们应该是等价的。谢谢
发布于 2014-03-22 22:35:12
在time_zone
文件中配置application.rb
,并按如下方式使用:
# application.rb:
class Application < Rails::Application
config.time_zone = 'America/New_York'
end
Time.zone.parse("2014-03-19T04:00:00.000Z").to_s
# => "2014-03-19 00:00:00 -0400"
更多使用实例
$ > Time.zone = "America/New_York"
# => "America/New_York"
$ > Time.zone
# => (GMT-05:00) America/New_York
$ > Time.zone.now
# => Sat, 22 Mar 2014 18:28:48 EDT -04:00
发布于 2014-03-22 22:39:22
irb(main):008:0> Time.parse("2014-03-19T04:00:00.000Z").getlocal.strftime("%F %T %z")
=> "2014-03-19 04:00:00 +0000"
在GMT+1中的系统上:
irb(main):003:0> Time.parse("2014-03-19T04:00:00.000Z").getlocal.strftime("%F %T %z")
=> "2014-03-19 05:00:00 +0100"
https://stackoverflow.com/questions/22584119
复制相似问题