Klasse MatchData

MatchData kapselt das Ergebnis eines Abgleichs eines Regexp mit einem String. Es wird von Regexp#match und String#match zurückgegeben und auch in einer globalen Variablen gespeichert, die von Regexp.last_match zurückgegeben wird.

Verwendung

url = 'https://docs.ruby-lang.de/en/2.5.0/MatchData.html'
m = url.match(/(\d\.?)+/)   # => #<MatchData "2.5.0" 1:"0">
m.string                    # => "https://docs.ruby-lang.de/en/2.5.0/MatchData.html"
m.regexp                    # => /(\d\.?)+/
# entire matched substring:
m[0]                        # => "2.5.0"

# Working with unnamed captures
m = url.match(%r{([^/]+)/([^/]+)\.html$})
m.captures                  # => ["2.5.0", "MatchData"]
m[1]                        # => "2.5.0"
m.values_at(1, 2)           # => ["2.5.0", "MatchData"]

# Working with named captures
m = url.match(%r{(?<version>[^/]+)/(?<module>[^/]+)\.html$})
m.captures                  # => ["2.5.0", "MatchData"]
m.named_captures            # => {"version"=>"2.5.0", "module"=>"MatchData"}
m[:version]                 # => "2.5.0"
m.values_at(:version, :module)
                            # => ["2.5.0", "MatchData"]
# Numerical indexes are working, too
m[1]                        # => "2.5.0"
m.values_at(1, 2)           # => ["2.5.0", "MatchData"]

Gleichwertigkeit globaler Variablen

Teile des letzten MatchData (zurückgegeben von Regexp.last_match) sind auch als globale Variablen aliasisiert

Siehe auch Globale Variablen bei Regexp.