我正在尝试将类似日期:2011-05-21 04:20:46.011解析为Rails中的Time对象。到目前为止,我有以下内容:
Time.strptime("2011-05-21 04:20:46.011", "%Y-%m-%d %H:%M:%S.%3N")
但它似乎不喜欢最后的“%3N”。我该如何解析这个日期?
答案 0 :(得分:8)
使用parse
:
x = Time.parse("2011-05-21 04:20:46.011", "%Y-%m-%d %H:%M:%S.%3N")
# => 2011-05-21 04:20:46 -0700
x.usec
# => 11000
在许多情况下,您无需传递以下格式:
x = Time.parse("2011-05-21 04:20:46.011")
# => 2011-05-21 04:20:46 -0700
x.usec
# => 11000
答案 1 :(得分:3)
尝试Time.parse(“2011-05-21 04:20:46.011”,“%Y-%m-%d%H:%M:%S。%3N”)
答案 2 :(得分:2)
在rails控制台中使用 Ruby v 2.3.2 和 Rails v 5.0.0.1
2.3.2 :035 > Time.parse("2011-05-21 04:20:46.011", "%Y-%m-%d %H:%M:%S.%3N")
NoMethodError: undefined method `getlocal' for "%Y-%m-%d %H:%M:%S.%3N":String
from /home/jignesh/.rvm/rubies/ruby-2.3.2/lib/ruby/2.3.0/time.rb:264:in `make_time'
from /home/jignesh/.rvm/rubies/ruby-2.3.2/lib/ruby/2.3.0/time.rb:366:in `parse'
from (irb):35
注意:在解析格式的下方代码中,不以%N
为前缀,而是以%3N
为小数位数,而只是指定%N
并且它可以正常工作
2.3.2 :037 > Time.strptime("2011-05-21 04:20:46.011", "%Y-%m-%d %H:%M:%S.%N")
=> 2011-05-21 04:20:46 +0530
2.3.2 :038 > tt = Time.strptime("2011-05-21 04:20:46.011", "%Y-%m-%d %H:%M:%S.%N")
=> 2011-05-21 04:20:46 +0530
2.3.2 :039 > tt.usec
=> 11000
使用parse
2.3.2 :040 > tt = Time.parse("2011-05-21 04:20:46.011", "%Y-%m-%d %H:%M:%S.%N")
NoMethodError: undefined method `getlocal' for "%Y-%m-%d %H:%M:%S.%N":String
from /home/jignesh/.rvm/rubies/ruby-2.3.2/lib/ruby/2.3.0/time.rb:264:in `make_time'
from /home/jignesh/.rvm/rubies/ruby-2.3.2/lib/ruby/2.3.0/time.rb:366:in `parse'
from (irb):40
看起来很奇怪,因为Time.strptime(date, format, now=self.now)官方文档明确提到了%3N
,%6N
和%9N
,并且在解析格式中使用它们不起作用!
Rails确实提供了对应的strptime(str, format, now=now())作为ActiveSupport::TimeZone
API的一部分,它在内部使用Ruby的标准DateTime._strptime
进行解析,如源代码所示:
# File activesupport/lib/active_support/values/time_zone.rb, line 382
def strptime(str, format, now=now())
parts_to_time(DateTime._strptime(str, format), now)
end
我猜DateTime._strptime内部委托给Ruby的标准Time.strptime
对于那些正在寻找利用Rails的Time.zone.parse
对应物进行特定格式解析的人,他们可以使用下面的代码:
tt = Time.zone.strptime('1999-12-31 14:00:00.011111', '%Y-%m-%d %H:%M:%S.%N')
=> Fri, 31 Dec 1999 14:00:00 UTC +00:00
2.3.2 :031 > tt.usec
=> 11111
希望来自核心团队的人能够澄清所观察到的这种行为,如果行为正常,那么至少应该在文档中做一个注释。