Rubyのselect/reject/filterの使い方を完全解説!初心者向けの条件抽出レシピ
生徒
「Rubyで、たくさんのデータの中から特定の条件に合うものだけを取り出したいときはどうすればいいですか?」
先生
「そんなときは、selectやfilter、それから逆の意味を持つrejectを使うと便利ですよ。」
生徒
「たくさんあって難しそうですね。どう使い分ければいいんですか?」
先生
「使い分けは意外とシンプルです。現実の道具に例えながら、一緒に基本をマスターしていきましょう!」
1. データの抽出とは?身近な例で考えよう
プログラミングにおいて抽出(ちゅうしゅつ)とは、大量にあるデータの中から、自分の欲しいものだけを選び抜く作業のことです。例えば、学校のテスト結果から「80点以上の人だけ」を選んだり、スマートフォンの連絡先から「家族」というグループだけを表示したりする動作がこれにあたります。
Rubyには、この「選び抜く作業」を専門に行う命令がいくつか用意されています。代表的なものがselect(セレクト)、filter(フィルター)、そしてreject(リジェクト)です。これらを使いこなすことで、複雑な条件でも一瞬でデータを整理できるようになります。
2. selectメソッドの基本的な使い方
selectは、英語で「選ぶ」という意味です。その名の通り、「条件に当てはまるものだけを拾い集める」ときに使います。これは「お買い物」でカゴに欲しいものだけを入れていく作業に似ています。
例えば、1から10までの数字が入ったリストから、偶数(2で割り切れる数)だけを取り出したい場合のプログラムを見てみましょう。Rubyでは配列(データの集まり)に対して、この命令を出すことができます。
numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
# 偶数だけを選び出す
even_numbers = numbers.select do |n|
n % 2 == 0
end
puts even_numbers
実行結果は以下のようになります。
2
4
6
8
10
このコードの中にあるn % 2 == 0は、「2で割った余りが0と等しいか」を確認する条件式です。selectはこの条件が「正しい(真)」となった数字だけを新しい配列に詰め込んでくれます。
3. filterとselectは何が違うの?
Rubyの新しいバージョンでは、selectと同じ機能を持つfilterという命令が追加されました。結論から言うと、この二つは全く同じ動きをします。なぜ二つあるのかというと、他の多くのプログラミング言語(JavaScriptやPythonなど)では「抽出」のことをfilterと呼ぶことが多いため、他の言語に慣れている人でも使いやすくするために導入されました。
「ろ過する(フィルターにかける)」というイメージの方がしっくりくる人はfilterを、「選別する」というイメージが好きな人はselectを使うと良いでしょう。初心者の方は、どちらか一方で使い慣れておけば問題ありません。
4. rejectメソッドは「除外」の専門家
selectが「欲しいものを選ぶ」のに対し、rejectは「いらないものを取り除く」ときに使います。日本語では「拒絶する」や「除外する」という意味があります。ゴミ箱に捨てるものを選別するようなイメージです。
例えば、果物のリストの中から、アレルギーがある「バナナ」だけを取り除いて、それ以外のリストを作りたい場合は以下のようになります。rejectを使うことで、「バナナ以外」という指示をスマートに書くことができます。
fruits = ["リンゴ", "バナナ", "オレンジ", "バナナ", "メロン"]
# バナナをリストから除外する
safe_fruits = fruits.reject do |fruit|
fruit == "バナナ"
end
puts safe_fruits
実行結果は以下のようになります。
リンゴ
オレンジ
メロン
もしこれをselectで書こうとすると「リンゴかオレンジかメロンなら選ぶ」という長い条件が必要になりますが、rejectなら「バナナなら捨てる」と一言で済むので、コードがとても読みやすくなります。
5. 文字列の長さでフィルタリングする応用技
抽出の条件は、数字の計算や名前の一致だけではありません。データの「長さ」や「種類」を使って選別することも可能です。例えば、SNSのユーザー名リストから、「3文字以下の短い名前の人だけ」を探し出してみましょう。
ここでは、文字列の長さを教えてくれるlengthという機能と組み合わせて使います。こうした組み合わせこそがプログラミングの醍醐味です。
users = ["タナカ", "サトウ", "スズキ", "リン", "アキ"]
# 名前の長さが3文字以下の人だけを抽出
short_names = users.select do |name|
name.length <= 3
end
puts "短い名前のリスト: #{short_names}"
実行結果は以下のようになります。
短い名前のリスト: ["タナカ", "サトウ", "スズキ", "リン", "アキ"]
カタカナは一文字が1としてカウントされます。今回の例では全員が3文字以下だったので、全員が抽出されました。もしここに「ハナダトモコ」という長い名前が混ざっていれば、その人は抽出されません。このように、データの中身を自動で判断して選別できるのが強みです。
6. 複雑な条件で「お宝」を探そう
より実用的な例として、商品の在庫リストから「価格が1000円以上」かつ「在庫があるもの」だけを抜き出すような状況を考えてみましょう。Rubyの配列の中には、さらに詳細なデータ(ハッシュと呼ばれるもの)を入れることができます。
ここでは、複数の条件を「かつ(&&)」という記号でつなぐ方法を学びます。初心者の方でも、一つ一つの意味を理解すれば難しいことはありません。
items = [
{ name: "ペン", price: 100, stock: true },
{ name: "ノート", price: 1500, stock: true },
{ name: "消しゴム", price: 50, stock: false },
{ name: "高級時計", price: 50000, stock: true }
]
# 1000円以上で、かつ在庫がある商品だけ選ぶ
valuable_items = items.select do |item|
item[:price] >= 1000 && item[:stock] == true
end
valuable_items.each do |item|
puts "おすすめ商品: #{item[:name]}"
end
実行結果は以下のようになります。
おすすめ商品: ノート
おすすめ商品: 高級時計
このように、大規模なネットショップの検索機能も、基本的にはこうした条件抽出の積み重ねで動いています。selectをマスターすれば、データ分析やアプリ開発の基礎が身についたと言っても過言ではありません。
7. 戻り値の重要性と「空」の場合の挙動
プログラミング未経験の方が覚えておくべき大事な概念に戻り値(もどりち)があります。これは命令を実行した結果として返ってくるデータのことです。selectやrejectは、常に「新しい配列」を返してくれます。元のデータセットは書き換えられないため、安心して何度でも試行錯誤できます。
もし、条件に合うものが一つもなかった場合はどうなるでしょうか?その場合は「空の配列(中身が何もない箱)」が返ってきます。エラーになってプログラムが止まってしまうわけではないので、初心者の方も恐れずに条件を書いてみてください。
8. 破壊的メソッドに注意しよう
これまでに紹介したselectなどは、元のデータを残したまま新しいデータを作りますが、中には元のデータそのものを書き換えてしまう命令もあります。これを破壊的メソッド(はかいてきめそっど)と呼び、Rubyでは名前に「!」がついたselect!やreject!がそれにあたります。
パソコンを触り始めたばかりの頃は、元のデータをうっかり消してしまうと困ることが多いはずです。まずは「!」のついていない安全な方法で練習し、プログラムの動きに慣れてから破壊的な方法を検討するようにしましょう。安全第一でコードを書くことが、トラブルを防ぐ最大のコツです。
9. selectとrejectの使い分けレシピ
最後に、どちらを使うか迷ったときの「鉄板レシピ」を整理しておきましょう。プログラミングは正解が一つではありませんが、読みやすいコードにはパターンがあります。
- 「〇〇なものだけ欲しい」と肯定的に考えるときは
select。 - 「〇〇以外は全部欲しい」と否定的に考えるときは
reject。 - 「多言語の知識を活かしたい」ときは
filter。
人間の言葉で説明したときに、より自然に聞こえる方を選ぶのが正解です。例えば「赤いボールを選んで」と言う方が「赤くないボールを捨てて」と言うよりも自然であれば、selectを使うべきです。このように、自分の思考に近い言葉をコードに落とし込んでいくのが、Rubyらしいプログラミングの楽しみ方です。