7

私はこのハッシュの配列を持っています:

results = [
   {"day"=>"2012-08-15", "name"=>"John", "calls"=>"5"},
   {"day"=>"2012-08-15", "name"=>"Bill", "calls"=>"8"},
   {"day"=>"2012-08-16", "name"=>"Bill", "calls"=>"11"},
]

結果を検索して、ビルが15日に行った電話の数を確認するにはどうすればよいですか?

「ハッシュの配列でキーと値のペアをRubyで簡単に検索する」の回答を読んだ後、次のfindステートメントを拡張する必要があると思います。

results.find { |h| h['day'] == '2012-08-15' }['calls']
4

5 に答える 5

15

あなたは正しい方向に進んでいます!

results.find {|i| i["day"] == "2012-08-15" and i["name"] == "Bill"}["calls"]
# => "8"
于 2012-08-22T19:44:20.337 に答える
1
results.select { |h| h['day'] == '2012-08-15' && h['name'] == 'Bill' }
  .reduce(0) { |res,h| res += h['calls'].to_i } #=> 8
于 2012-08-22T19:48:23.730 に答える
0

本当に不器用な実装;)

def get_calls(hash,name,date) 
 hash.map{|result| result['calls'].to_i if result['day'] == date && result["name"] == name}.compact.reduce(:+)
end

date = "2012-08-15"
name = "Bill"

puts get_calls(results, name, date)
=> 8 
于 2012-08-22T19:44:00.443 に答える
0

実際、「reduce」または「inject」は、特にこの正確な操作のためのものです(列挙可能なものの内容を単一の値に減らすには:

results.reduce(0) do |count, value|
  count + ( value["name"]=="Bill" && value["day"] == "2012-08-15" ? value["calls"].to_i : 0)
end

ここに素晴らしい記事があります:「マップを理解して削減する

于 2012-08-22T20:05:10.210 に答える
0

または別の可能な方法ですが、少し悪いことに、injectを使用します。

results.inject(0) { |number_of_calls, arr_element| arr_element['day'] == '2012-08-15' ? number_of_calls += 1 : number_of_calls += 0  }

各反復でnumber_of_callsを設定する必要があることに注意してください。そうしないと、機能しません。たとえば、これは機能しません。

p results.inject(0) { |number_of_calls, arr_element| number_of_calls += 1 if arr_element['day'] == '2012-08-15'}
于 2012-08-22T20:11:57.067 に答える