我正在尝试将日期(如: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.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
希望核心团队的某个人能够澄清观察到的这种行为,如果这种行为是正常的,那么至少应该在文档中记录下来。