我有一个文件,其中包含 2 个不同时间的行,如下所示:
01:31:51,210 --> 01:31:54,893
格式为hours:minutes:seconds,milliseconds
. 我的问题是如何将这两次分成两个数组。 line.split(':', ',')
不起作用。
我有一个文件,其中包含 2 个不同时间的行,如下所示:
01:31:51,210 --> 01:31:54,893
格式为hours:minutes:seconds,milliseconds
. 我的问题是如何将这两次分成两个数组。 line.split(':', ',')
不起作用。
require 'time'
s = '01:31:51,210 --> 01:31:54,893'
a = s.split(' --> ') # => ["01:31:51,210", "01:31:54,893"]
b1 = a.map{|a1| a1.split(/[:,]/)} # => [["01", "31", "51", "210"], ["01", "31", "54", "893"]]
或者,您可以直接解析为Time
对象
b2 = a.map{|a1| Time.parse(a1)} # => [2013-06-05 01:31:51 +0400, 2013-06-05 01:31:54 +0400]
拆分一次,然后在结果上再次拆分(使用正则表达式):
line.split(" --> ").map { |l| l.split(/[:,]/) }