13

是否有宝石或其他东西可以解析诸如“4h 30m”“1d 4h”之类的字符串 - 有点像 JIRA 或任务规划器中的估计值,也许是国际化?

4

5 回答 5

15

发布第二个答案,因为慢性(我的原始答案建议)不会给你时间跨度而是时间戳。

这是我的解析器。

class TimeParser
  TOKENS = {
    "m" => (60),
    "h" => (60 * 60),
    "d" => (60 * 60 * 24)
  }

  attr_reader :time

  def initialize(input)
    @input = input
    @time = 0
    parse
  end

  def parse
    @input.scan(/(\d+)(\w)/).each do |amount, measure|
      @time += amount.to_i * TOKENS[measure]
    end
  end
end

该策略相当简单。拆分"5h"为,定义代表 ( ) 的["5", "h"]秒数,并将该数量添加到。"h"TOKENS@time

TimeParser.new("1m").time
# => 60

TimeParser.new("1m wtf lol").time
# => 60

TimeParser.new("4h 30m").time
# => 16200

TimeParser.new("1d 4h").time
# => 100800

处理它也不应该太难"1.5h",看到代码库就这么简单。

于 2009-03-19T07:49:00.523 回答
10

chronic_duration做这个。

于 2009-12-17T17:13:17.563 回答
6

你可以用慢性的。它几乎可以解析你所掌握的所有内容,包括“昨天”、“上周”等。

更新:正如 OP 在评论中指出的那样,Chronic 是针对日期,而不是时间跨度。请参阅我的另一个答案。

于 2009-03-18T11:16:02.843 回答
3

我写了这个方法做得很好

  def parse_duration(dur)
    duration = 0

    number_tokens = dur.gsub(/[a-z]/i,"").split
    times = dur.gsub(/[\.0-9]/,"").split

    if number_tokens.size != times.size
      raise "unrecognised duration!"
    else
      dur_tokens = number_tokens.zip(times)

      for d in dur_tokens
        number_part = d[0].to_f
        time_part = d[1]

        case time_part.downcase
        when "h","hour","hours"
          duration += number_part.hours
        when "m","minute","minutes","min","mins"
          duration += number_part.minutes
        when "d","day","days"
          duration += number_part.days
        when "w","week","weeks"
          duration += number_part.weeks
        when "month", "months"
          duration += number_part.months
        when "y", "year", "years"
          duration += number_part.years
        else
          raise "unrecognised duration!"
        end

      end

    end

    duration
  end
于 2009-03-18T11:20:44.907 回答
1

解析成什么?

这将解析为一个哈希:

"4h 30m".split(/\s/).each{|i| h[i.gsub(/\d+/,"")] = i.gsub(/\w/,"")}

对不起。不熟悉JIRA....

于 2009-03-18T08:34:35.443 回答