English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

Ruby 范囲(Range)

範囲(Range)は至る所にあります:aからz、0から 9など。Rubyは範囲をサポートし、範囲をさまざまな方法で使用できます:

  • シーケンスとしての範囲

  • 条件としての範囲

  • 範囲としての使用

シーケンスとしての範囲

範囲の最初で最も一般的な用途はシーケンスの表現です。シーケンスには起点、終点、シーケンスが連続的な値を生成する方法があります。

Rubyは ''..'' および ''...'' 範囲演算子はこれらのシーケンスを作成します。二点形式は指定された最高値を含む範囲を作成し、三点形式は指定された最高値を含まない範囲を作成します。

(1..5)        #==> 1, 2, 3, 4, 5
(1...5)       #==> 1, 2, 3, 4
('a'..'d')    #==> 'a', 'b', 'c', 'd'

シーケンス 1..100 は Range オブジェクト、2つの Fixnum オブジェクトの参照。必要であれば、以下を使用できます to_a メソッドは範囲をリストに変換します。以下の例を試してみてください:

オンラインサンプル

#!/usr/bin/ruby
 
$, =", "   # Array 値分隔符
range1 =1..10).to_a
range2 = ('bar'..'bat').to_a
 
puts "#{range1]
puts "#{range2]

以上の例の実行結果は以下の通りです:

[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
["bar", "bas", "bat"]

範囲は、その内容をさまざまな方法で確認できるように、メソッドを実装しています:

オンラインサンプル

#!/usr/bin/ruby
# -*- coding: UTF-8 -*-
 
# 指定範囲
digits = 0..9
 
puts digits.include?(}5)
ret = digits.min
puts "最小値は #{ret}"
 
ret = digits.max
puts "最大値は #{ret}"
 
ret = digits.reject {|i| i < 5 }
puts "条件に一致しないのは #{ret}"
 
digits.each do |digit|
   puts "ループ内で #{digit}"
end

以上の例の実行結果は以下の通りです:

true
最小値は 0
最大値は 9
条件に一致しないのは [5, 6, 7, 8, 9]
ループ内で 0
ループ内で 1
ループ内で 2
ループ内で 3
ループ内で 4
ループ内で 5
ループ内で 6
ループ内で 7
ループ内で 8
ループ内で 9

条件としての範囲

範囲は条件表現としても使用できます。例えば、以下のコードスニペットは標準入力から行を印刷し、各集合の最初の行に単語が含まれています start、最後の行には単語が含まれています end.:

while gets
   print if /start/../end/
end

範囲はcase文で使用できます:

オンラインサンプル

#!/usr/bin/ruby
# -*- coding: UTF-8 -*-
 
score = 70
 
result = case score
when 0..40
    "糟糕的分数"
when 41..60
    "快要及格"
when 61..70
    "及格分数"
when 71..100
       "良好分数"
else
    "错误的分数"
end
 
puts result

以上の例の実行結果は以下の通りです:

合格点

範囲としての使用

範囲の最後の用途は、指定された範囲内にあるかどうかの間隔検出です。計算には === この等価演算子を使用する必要があります。

オンラインサンプル

#!/usr/bin/ruby
# -*- coding: UTF-8 -*-
 
if (1..10) === 5)
  puts "5 在 (1..10)"
end
 
if (('a'..'j') === 'c')
  puts "c 在 ('a'..'j')"
end
 
if (('a'..'j') === 'z')
  puts "z 在 ('a'..'j')"
end

以上の例の実行結果は以下の通りです:

5 在 (1..10)
c 在 ('a'..'j')