RubyonRails 3时间-解析毫秒



我正在尝试将日期(如: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"。如何解析此日期?

使用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

尝试时间。解析("2011-05-21 04:20:46.011","%Y-%m-%d%H:%m:%S。%3N")

在Rails控制台中使用Ruby v 2.3.2Rails 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 

希望核心团队的某个人能够澄清观察到的这种行为,如果这种行为是正常的,那么至少应该在文档中记录下来。

相关内容

  • 没有找到相关文章