简体   繁体   中英

How to sort by time an array of hashes?

What's the best approach to sort by time an array of hashes?

[
  {:scenario_name=>"Scenario: Two different numbers", :scenario_line=>5, :feature_file=>"multiplication.feature", :time=>"0m2.004s"},
  {:scenario_name=>"Scenario: Sum of many numbers", :scenario_line=>6, :feature_file=>"addition.feature", :time=>"0m22.031s"},
  {:scenario_name=>"Scenario: Regular numbers", :scenario_line=>5, :feature_file=>"division.feature", :time=>"0m3.004s"},
  {:scenario_name=>"Scenario: Subtract two different numbers", :scenario_line=>6, :feature_file=>"subtraction.feature", :time=>"0m3.004s"}
]

So, I'm expecting to have it sorted by time (in descending order) like:

[
  {:scenario_name=>"Scenario: Sum of many numbers", :scenario_line=>6, :feature_file=>"addition.feature", **:time=>"0m22.031s**"},
  {:scenario_name=>"Scenario: Regular numbers", :scenario_line=>5, :feature_file=>"division.feature", **:time=>"0m3.004s**"},
  {:scenario_name=>"Scenario: Subtract two different numbers", :scenario_line=>6, :feature_file=>"subtraction.feature", **:time=>"0m3.004s**"},
  {:scenario_name=>"Scenario: Two different numbers", :scenario_line=>5, :feature_file=>"multiplication.feature", **:time=>"0m2.004s**"}
]

The times are String s, so do I need to convert it to Int before? Or is there any way to sort it?

array.sort_by{|h| h[:time].scan(/[\d.]+/).map(&:to_f)}.reverse

How about this?

ary = [
    {:scenario_name=>"Scenario: Two different numbers", :scenario_line=>5, :feature_file=>"multiplication.feature", :time=>"0m2.004s"},
    {:scenario_name=>"Scenario: Sum of many numbers", :scenario_line=>6, :feature_file=>"addition.feature", :time=>"0m22.031s"},
    {:scenario_name=>"Scenario: Regular numbers", :scenario_line=>5, :feature_file=>"division.feature", :time=>"0m3.004s"},
    {:scenario_name=>"Scenario: Subtract two different numbers", :scenario_line=>6, :feature_file=>"subtraction.feature", :time=>"0m3.004s"}
]

ary = ary.sort_by do |hash|
  match = /(\d+)m([\d.]+)s/.match hash[:time]
  -(match[1].to_f * 60 + match[2].to_f)
end

ary.each { |hash| p hash }

output

{:scenario_name=>"Scenario: Sum of many numbers", :scenario_line=>6, :feature_file=>"addition.feature", :time=>"0m22.031s"}
{:scenario_name=>"Scenario: Subtract two different numbers", :scenario_line=>6, :feature_file=>"subtraction.feature", :time=>"0m3.004s"}
{:scenario_name=>"Scenario: Regular numbers", :scenario_line=>5, :feature_file=>"division.feature", :time=>"0m3.004s"}
{:scenario_name=>"Scenario: Two different numbers", :scenario_line=>5, :feature_file=>"multiplication.feature", :time=>"0m2.004s"}
arr = [
  {:scenario_name=>"Scenario: Two different numbers", :scenario_line=>5, :feature_file=>"multiplication.feature", :time=>"0m2.004s"},
  {:scenario_name=>"Scenario: Sum of many numbers", :scenario_line=>6, :feature_file=>"addition.feature", :time=>"0m22.031s"},
  {:scenario_name=>"Scenario: Regular numbers", :scenario_line=>5, :feature_file=>"division.feature", :time=>"0m3.004s"},
  {:scenario_name=>"Scenario: Subtract two different numbers", :scenario_line=>6, :feature_file=>"subtraction.feature", :time=>"0m3.004s"}
]

arr.sort_by{|i| i[:time].scan(/\d+/).map{|i| -i.to_i}} 
# => [{:scenario_name=>"Scenario: Sum of many numbers",
#      :scenario_line=>6,
#      :feature_file=>"addition.feature",
#      :time=>"0m22.031s"},
#     {:scenario_name=>"Scenario: Subtract two different numbers",
#      :scenario_line=>6,
#      :feature_file=>"subtraction.feature",
#      :time=>"0m3.004s"},
#     {:scenario_name=>"Scenario: Regular numbers",
#      :scenario_line=>5,
#      :feature_file=>"division.feature",
#      :time=>"0m3.004s"},
#     {:scenario_name=>"Scenario: Two different numbers",
#      :scenario_line=>5,
#      :feature_file=>"multiplication.feature",
#      :time=>"0m2.004s"}]

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM