1

我有一个文件,其中包含 2 个不同时间的行,如下所示:

01:31:51,210 --> 01:31:54,893

格式为hours:minutes:seconds,milliseconds. 我的问题是如何将这两次分成两个数组。 line.split(':', ',')不起作用。

4

2 回答 2

3
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]
于 2013-06-05T19:34:06.817 回答
1

拆分一次,然后在结果上再次拆分(使用正则表达式): line.split(" --> ").map { |l| l.split(/[:,]/) }

于 2013-06-05T19:32:53.610 回答