カテゴリ: Ruby 更新日: 2026/01/01

Ruby配列とハッシュの変換をやさしく解説!to_h・zip・assoc・rassoc完全入門

配列↔ハッシュ変換:to_h・zip・assoc/rassoc の活用術
配列↔ハッシュ変換:to_h・zip・assoc/rassoc の活用術

先生と生徒の会話形式で理解しよう

生徒

「Rubyの配列って、ハッシュに変えたりできますか?なんだか難しそうで…」

先生

「できますよ。配列とハッシュは形が違うだけで、変換の方法を知れば身近な存在になります。」

生徒

「パソコンをあまり触ったことがなくても理解できますか?」

先生

「大丈夫です。買い物メモや名簿の例えで、一つずつ確認していきましょう。」

1. 配列とハッシュの違いを超かんたんに理解しよう

1. 配列とハッシュの違いを超かんたんに理解しよう
1. 配列とハッシュの違いを超かんたんに理解しよう

Rubyの配列(Array)は、順番に並んだ箱の集まりです。番号札が付いたロッカーのようなもので、 一番目、二番目と位置で中身を取り出します。

一方でハッシュ(Hash)は、「名前」と「中身」がセットになった引き出しです。 名簿や辞書のように、「何がキーで、何が値か」がはっきりしています。

プログラミングでは、データを扱いやすくするために、配列からハッシュへ、またはその逆へ 変換する場面がよくあります。ここで登場するのがto_hzipassocrassocです。

2. to_hで配列をハッシュに変換する基本

2. to_hで配列をハッシュに変換する基本
2. to_hで配列をハッシュに変換する基本

to_hは、配列をハッシュに変換するための命令です。 ただし、使うには「二つセットの配列」が必要になります。

例えば「商品名」と「値段」がペアになっているイメージです。


items = [["りんご", 100], ["みかん", 80]]
hash = items.to_h
p hash

{"りんご"=>100, "みかん"=>80}

このように、配列の中身が「キー」と「値」に分かれて、ハッシュに変換されます。 データを整理したいときによく使われる基本ワザです。

3. zipで二つの配列を合体させる

3. zipで二つの配列を合体させる
3. zipで二つの配列を合体させる

zipは、二つの配列を横に並べてセットにする命令です。 名簿で言えば、「名前の一覧」と「年齢の一覧」を合体させる感覚です。


names = ["太郎", "花子"]
ages = [20, 18]
pairs = names.zip(ages)
p pairs

[["太郎", 20], ["花子", 18]]

この結果にto_hを使えば、そのままハッシュに変換できます。 配列と配列からハッシュを作りたいときの定番の流れです。

4. assocとrassocで特定のデータを探す

4. assocとrassocで特定のデータを探す
4. assocとrassocで特定のデータを探す

assocrassocは、少し変わった命令ですが、 「ペアの配列」から条件に合うものを探すために使います。

assocは左側、rassocは右側を見る、と覚えると簡単です。


data = [["太郎", 20], ["花子", 18]]
p data.assoc("太郎")
p data.rassoc(18)

["太郎", 20]
["花子", 18]

名前から年齢を探したり、年齢から名前を逆に探したりできます。 データが増えてきたときに役立つ便利な検索方法です。

5. 配列とハッシュを変換できると何がうれしい?

5. 配列とハッシュを変換できると何がうれしい?
5. 配列とハッシュを変換できると何がうれしい?

Rubyで配列とハッシュの変換を覚えると、データの整理や検索がとても楽になります。 プログラミングでは「形を変える」ことで、処理が一気に簡単になることが多いです。

最初は難しく感じますが、買い物リストや名簿の例で考えると、 配列とハッシュは日常生活に近い存在だと分かります。

to_h、zip、assoc、rassocは、Rubyの配列操作の中でも よく使われる基本セットなので、ぜひ手を動かしながら慣れていきましょう。

関連記事:
カテゴリの一覧へ
新着記事
New1
Rails
Rails GoodJob入門!PostgreSQLベースのバックグラウンド処理を初心者向けに完全解説
New2
Ruby
Rubyで学ぶビット演算入門:&・|・^・~・<<・>>の基礎と実例
New3
Rails
RESTとRailsの関係を徹底解説!resources設計と7つの標準アクションを初心者向けにわかりやすく解説
New4
データベース
MySQLアーキテクチャ入門!初心者向けに基本構造と仕組みを徹底解説
人気記事
No.1
Java&Spring記事人気No1
Ruby
Rubyのreduceとinject入門!合計計算や集計を初心者向けに分かりやすく解説
No.2
Java&Spring記事人気No2
Ruby
Rubyの始め方ガイド:インストールから最初のHello Worldまで(Windows/Mac/Linux)
No.3
Java&Spring記事人気No3
Ruby
Rubyの文字列エンコーディング完全ガイド!Encoding・force_encoding・encodeを初心者向け解説
No.4
Java&Spring記事人気No4
データベース
PostgreSQLのWHERE句を徹底解説!初心者でもわかるSQLデータ抽出の基本
No.5
Java&Spring記事人気No5
Ruby
Rubyのfind/detect/find_indexを徹底解説!目的のデータを素早く探す方法
No.6
Java&Spring記事人気No6
Ruby
Rubyのselect/reject/filterの使い方を完全解説!初心者向けの条件抽出レシピ
No.7
Java&Spring記事人気No7
Ruby
Rubyで比較演算子を完全解説!==・===・<=>・eql? の使い分け
No.8
Java&Spring記事人気No8
データベース
PostgreSQLで順位付け!ROW_NUMBER関数の使い方を初心者向けに徹底解説