Ruby-ranges

提供:Dev Guides
移動先:案内検索

ルビー-範囲

範囲はどこでも発生します:1月から12月、0から9行、50から67行など。 Rubyは範囲をサポートしており、さまざまな方法で範囲を使用できます-

  • シーケンスとしての範囲
  • 条件としての範囲
  • 間隔としての範囲

シーケンスとしての範囲

範囲の最初で、おそらく最も自然な使用法は、シーケンスを表現することです。 シーケンスには、開始点、終了点、およびシーケンス内の連続した値を生成する方法があります。

Rubyは、 .. および …​ 範囲演算子を使用してこれらのシーケンスを作成します。 2ドット形式は包括的範囲を作成し、3ドット形式は指定された高い値を除外する範囲を作成します。

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

シーケンス1..100は、2つの_Fixnum_オブジェクトへの参照を含むRange _object_として保持されます。 必要な場合は、_to_a_メソッドを使用して範囲をリストに変換できます。 次の例を試してください-

#!/usr/bin/ruby

$, =", "   # Array value separator
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

# Assume a range
digits = 0..9

puts digits.include?(5)
ret = digits.min
puts "Min value is #{ret}"

ret = digits.max
puts "Max value is #{ret}"

ret = digits.reject {|i| i < 5 }
puts "Rejected values are #{ret}"

digits.each do |digit|
   puts "In Loop #{digit}"
end

これは、次の結果を生成します-

true
Min value is 0
Max value is 9
Rejected values are 5, 6, 7, 8, 9
In Loop 0
In Loop 1
In Loop 2
In Loop 3
In Loop 4
In Loop 5
In Loop 6
In Loop 7
In Loop 8
In Loop 9

条件としての範囲

範囲は条件式としても使用できます。 たとえば、次のコードフラグメントは標準入力から行のセットを印刷します。各セットの最初の行には単語_start_が含まれ、最後の行には単語_ends_が含まれます-

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

範囲は、caseステートメントで使用できます-

#!/usr/bin/ruby

score = 70

result = case score
   when 0..40 then "Fail"
   when 41..60 then "Pass"
   when 61..70 then "Pass with Merit"
   when 71..100 then "Pass with Distinction"
   else "Invalid Score"
end

puts result

これは、次の結果を生成します-

Pass with Merit

間隔としての範囲

汎用範囲の最後の使用法は、間隔テストとしてです。ある値が範囲で表される間隔内に収まるかどうかを確認します。 これは、ケース等価演算子===を使用して行われます。

#!/usr/bin/ruby

if ((1..10) === 5)
   puts "5 lies in (1..10)"
end

if (('a'..'j') === 'c')
   puts "c lies in ('a'..'j')"
end

if (('a'..'j') === 'z')
   puts "z lies in ('a'..'j')"
end

これは、次の結果を生成します-

5 lies in (1..10)
c lies in ('a'..'j')