前提・実現したいこと
最終的にはハッシュとして使うので、ハッシュとしたのですが、
・値が構造体になっているハッシュを
・複数2つの値の昇順に
ソートすることはできるでしょうか。
ハッシュは「キーを使って、値を参照する」使い方をするのが本来の使い方だと理解しています。
ハッシュをソートすることや順番に処理すること自体、間違いでしょうか。
※ ハッシュの2つの値が同じものは、グループとして扱いたいので、ソートをしようと考えました。
発生している問題・エラーメッセージ
下記のハッシュをageとbirthdayの昇順にソートしたいのですが、できないものでしょうか。
配列であれば、ソートはできました。
該当のソースコード
ruby
1hashSt = Struct.new(:age,:birthday,:no) 2 birthHash = Hash.new 3 birthHash['Dave'] = hashSt.new("7","1205",0) 4 birthHash['Carol'] = hashSt.new("5","0823",0) 5 birthHash['Bob'] = hashSt.new("3","0131",0) 6 7birthHash.each do |key,val| 8 print key,"\t",val[:age],"\t",val[:birthday],"\n" 9end
実行結果
Dave 7 1205 Carol 5 0823 Bob 3 0131
やりたいことを配列で実現ました。「この結果にNo.を振ってハッシュを作る」方法であれば
目的は実現できます。
ruby
1arr = [ { :name => "Dave", :age => 7, :birthday => '1205' }, 2 { :name => "Carol", :age => 5, :birthday => '0823' }, 3 { :name => "Alice3", :age => 6, :birthday => '0303' }, 4 { :name => "Alice2", :age => 6, :birthday => '0202' }, 5 { :name => "Alice1", :age => 6, :birthday => '0101' }, 6 { :name => "Bob", :age => 3, :birthday => '0131' } ] 7 8#newsh = arr.sort{ |a, b| (a[:age] == b[:age]) ? a[:birthday] <=> b[:birthday] : a[:a ge] <=> b[:age] } 9newsh = arr.sort{ |a, b| ( (a[:age] <=> b[:age]).nonzero? || (a[:birthday] <=> b[:bir thday])) } 10 11newsh.each{|value| 12 print value[:name]," ",value[:age]," ",value[:birthday],"\n" 13 14}
実行結果
Bob 3 0131 Carol 5 0823 Alice1 6 0101 Alice2 6 0202 Alice3 6 0303 Dave 7 1205
試したこと(回避策として)
配列に一度保存して、ソートしてから、順に読み込んでハッシュを作成する方法で
回避しようと考えています。
補足情報(FW/ツールのバージョンなど)
ruby 2.3.7 で実行しています
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2019/05/30 04:40