質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

ソート

複数のデータを、順序性に従って並べ替えること。 データ処理を行う際に頻繁に用いられ、多くのアルゴリズムが存在します。速度、容量、複雑さなどに違いがあり、高速性に特化したものにクイックソートがあります。

ハッシュ

ハッシュは、高速にデータ検索を行うアルゴリズムのことです。

Q&A

解決済

1回答

1437閲覧

Rubyの値が構造体となっているハッシュを値でソートできますか

taro373

総合スコア189

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

ソート

複数のデータを、順序性に従って並べ替えること。 データ処理を行う際に頻繁に用いられ、多くのアルゴリズムが存在します。速度、容量、複雑さなどに違いがあり、高速性に特化したものにクイックソートがあります。

ハッシュ

ハッシュは、高速にデータ検索を行うアルゴリズムのことです。

1グッド

1クリップ

投稿2019/05/29 03:20

前提・実現したいこと

最終的にはハッシュとして使うので、ハッシュとしたのですが、
・値が構造体になっているハッシュを
・複数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 で実行しています

DrqYuto👍を押しています

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

ハッシュは順番を維持はできますが直接ソートする機能はありませんので、いったん配列に変換してソートを行い、それからハッシュに戻す必要があります。

投稿2019/05/29 03:30

maisumakun

総合スコア145183

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

taro373

2019/05/30 04:40

ありがとうございます。 csvファイルを配列に読み込んで、ソートして グループ分けして、グループ番号をつけてから ハッシュを作成することにしました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問