Ruby - Expressions régulières
Une expression régulière est une séquence spéciale de caractères qui vous aide à faire correspondre ou à trouver d'autres chaînes ou ensembles de chaînes à l'aide d'une syntaxe spécialisée contenue dans un modèle.
Un littéral d'expression régulière est un modèle entre des barres obliques ou entre des délimiteurs arbitraires suivis de% r comme suit -
Syntaxe
/pattern/
/pattern/im # option can be specified
%r!/usr/local! # general delimited regular expression
Exemple
#!/usr/bin/ruby
line1 = "Cats are smarter than dogs";
line2 = "Dogs also like meat";
if ( line1 =~ /Cats(.*)/ )
puts "Line1 contains Cats"
end
if ( line2 =~ /Cats(.*)/ )
puts "Line2 contains Dogs"
end
Cela produira le résultat suivant -
Line1 contains Cats
Modificateurs d'expression régulière
Les littéraux d'expression régulière peuvent inclure un modificateur facultatif pour contrôler divers aspects de la correspondance. Le modificateur est spécifié après le deuxième caractère barre oblique, comme indiqué précédemment et peut être représenté par l'un de ces caractères -
N ° Sr. | Modificateur et description |
---|---|
1 | i Ignore la casse lors de la mise en correspondance du texte. |
2 | o Effectue # {} interpolations une seule fois, la première fois que le littéral de l'expression rationnelle est évalué. |
3 | x Ignore les espaces et autorise les commentaires dans les expressions régulières. |
4 | m Correspond à plusieurs lignes, reconnaissant les nouvelles lignes comme des caractères normaux. |
5 | u,e,s,n Interprète l'expression rationnelle comme Unicode (UTF-8), EUC, SJIS ou ASCII. Si aucun de ces modificateurs n'est spécifié, l'expression régulière est supposée utiliser le codage source. |
Comme les chaînes de caractères délimitées par% Q, Ruby vous permet de commencer vos expressions régulières par% r suivi d'un délimiteur de votre choix. Ceci est utile lorsque le modèle que vous décrivez contient beaucoup de caractères de barre oblique que vous ne voulez pas échapper -
# Following matches a single slash character, no escape required
%r|/|
# Flag characters are allowed with this syntax, too
%r[</(.*)>]i
Modèles d'expressions régulières
Sauf pour les caractères de contrôle, (+ ? . * ^ $ ( ) [ ] { } | \), tous les personnages se correspondent. Vous pouvez échapper un caractère de contrôle en le précédant d'une barre oblique inverse.
N ° Sr. | Modèle et description |
---|---|
1 | ^ Correspond au début de la ligne. |
2 | $ Correspond à la fin de la ligne. |
3 | . Correspond à n'importe quel caractère unique sauf le saut de ligne. L'utilisation de l'option m lui permet également de correspondre à la nouvelle ligne. |
4 | [...] Correspond à n'importe quel caractère unique entre crochets. |
5 | [^...] Correspond à n'importe quel caractère unique non entre crochets |
6 | re* Correspond à 0 occurrences ou plus de l'expression précédente. |
sept | re+ Correspond à une ou plusieurs occurrences de l'expression précédente. |
8 | re? Correspond à 0 ou 1 occurrence de l'expression précédente. |
9 | re{ n} Correspond exactement au nombre n d'occurrences de l'expression précédente. |
dix | re{ n,} Correspond à n occurrences ou plus de l'expression précédente. |
11 | re{ n, m} Correspond à au moins n et au plus m occurrences de l'expression précédente. |
12 | a| b Correspond à a ou b. |
13 | (re) Regroupe les expressions régulières et mémorise le texte correspondant. |
14 | (?imx) Bascule temporairement sur les options i, m ou x dans une expression régulière. Si entre parenthèses, seule cette zone est affectée. |
15 | (?-imx) Désactive temporairement les options i, m ou x dans une expression régulière. Si entre parenthèses, seule cette zone est affectée. |
16 | (?: re) Regroupe les expressions régulières sans se souvenir du texte correspondant. |
17 | (?imx: re) Active temporairement les options i, m ou x entre parenthèses. |
18 | (?-imx: re) Désactive temporairement les options i, m ou x entre parenthèses. |
19 | (?#...) Commentaire. |
20 | (?= re) Spécifie la position à l'aide d'un motif. N'a pas de gamme. |
21 | (?! re) Spécifie la position à l'aide de la négation du motif. N'a pas de gamme. |
22 | (?> re) Correspond à un motif indépendant sans retour en arrière. |
23 | \w Correspond aux caractères des mots. |
24 | \W Correspond aux caractères non-mots. |
25 | \s Correspond aux espaces. Équivaut à [\ t \ n \ r \ f]. |
26 | \S Correspond à un espace non blanc. |
27 | \d Correspond aux chiffres. Équivalent à [0-9]. |
28 | \D Correspond aux non-chiffres. |
29 | \A Correspond au début de la chaîne. |
30 | \Z Correspond à la fin de la chaîne. Si une nouvelle ligne existe, elle correspond juste avant la nouvelle ligne. |
31 | \z Correspond à la fin de la chaîne. |
32 | \G Correspond au point où le dernier match s'est terminé. |
33 | \b Correspond aux limites des mots en dehors des crochets. Correspond à l'espace arrière (0x08) lorsqu'il est entre crochets. |
34 | \B Correspond aux limites autres que des mots. |
35 | \n, \t, etc. Correspond aux retours à la ligne, aux retours chariot, aux tabulations, etc. |
36 | \1...\9 Correspond à la nième sous-expression groupée. |
37 | \10 Correspond à la nième sous-expression groupée si elle correspond déjà. Sinon, fait référence à la représentation octale d'un code de caractère. |
Exemples d'expressions régulières
N ° Sr. | Exemple et description |
---|---|
1 | /ruby/ Correspond à «ruby». |
2 | ¥ Correspond au signe Yen. Les caractères multi-octets sont pris en charge dans Ruby 1.9 et Ruby 1.8. |
N ° Sr. | Exemple et description |
---|---|
1 | /[Rr]uby/ Correspond à "Ruby" ou "ruby". |
2 | /rub[ye]/ Correspond à "ruby" ou "rube". |
3 | /[aeiou]/ Correspond à n'importe quelle voyelle minuscule. |
4 | /[0-9]/ Correspond à n'importe quel chiffre; identique à / [0123456789] /. |
5 | /[a-z]/ Correspond à toute lettre ASCII minuscule. |
6 | /[A-Z]/ Correspond à n'importe quelle lettre ASCII majuscule. |
sept | /[a-zA-Z0-9]/ Correspond à l'un des éléments ci-dessus. |
8 | /[^aeiou]/ Correspond à tout autre chose qu'une voyelle minuscule. |
9 | /[^0-9]/ Correspond à tout autre chose qu'un chiffre. |
N ° Sr. | Exemple et description |
---|---|
1 | /./ Correspond à n'importe quel caractère sauf le saut de ligne. |
2 | /./m En mode multiligne, correspond également à la nouvelle ligne. |
3 | /\d/ Correspond à un chiffre: / [0-9] /. |
4 | /\D/ Correspond à un non-chiffre: / [^ 0-9] /. |
5 | /\s/ Correspond à un caractère d'espacement: / [\ t \ r \ n \ f] /. |
6 | /\S/ Correspond à des espaces non blancs: / [^ \ t \ r \ n \ f] /. |
sept | /\w/ Correspond à un caractère de mot unique: / [A-Za-z0-9 _] /. |
8 | /\W/ Correspond à un caractère autre qu'un mot: / [^ A-Za-z0-9 _] /. |
N ° Sr. | Exemple et description |
---|---|
1 | /ruby?/ Correspond à «frotter» ou «ruby»: le y est facultatif. |
2 | /ruby*/ Correspond à "frotter" plus 0 ou plus de y. |
3 | /ruby+/ Correspond à «frotter» plus 1 ou plus de y. |
4 | /\d{3}/ Correspond exactement à 3 chiffres. |
5 | /\d{3,}/ Correspond à 3 chiffres ou plus. |
6 | /\d{3,5}/ Correspond à 3, 4 ou 5 chiffres. |
Cela correspond au plus petit nombre de répétitions -
N ° Sr. | Exemple et description |
---|---|
1 | /<.*>/ Répétition gourmande: correspond à "<ruby> perl>". |
2 | /<.*?>/ Non gourmand: correspond à "<ruby>" dans "<ruby> perl>". |
N ° Sr. | Exemple et description |
---|---|
1 | /\D\d+/ Aucun groupe: + répète \ d |
2 | /(\D\d)+/ Groupé: + répète \ D \ d paire |
3 | /([Rr]uby(, )?)+/ Correspond à "Ruby", "Ruby, ruby, ruby", etc. |
Cela correspond à nouveau à un groupe précédemment apparié -
N ° Sr. | Exemple et description |
---|---|
1 | /([Rr])uby&\1ails/ Compatible avec ruby & rails ou Ruby & Rails. |
2 | /(['"])(?:(?!\1).)*\1/ Chaîne entre guillemets simples ou doubles. \ 1 correspond quel que soit le premier groupe correspondant. \ 2 correspond quel que soit le 2e groupe, etc. |
N ° Sr. | Exemple et description |
---|---|
1 | /ruby|rube/ Correspond à "ruby" ou "rube". |
2 | /rub(y|le))/ Correspond à "ruby" ou "rouble". |
3 | /ruby(!+|\?)/ "rubis" suivi d'un ou plusieurs! ou un ? |
Il doit spécifier la position de correspondance.
N ° Sr. | Exemple et description |
---|---|
1 | /^Ruby/ Correspond à "Ruby" au début d'une chaîne ou d'une ligne interne. |
2 | /Ruby$/ Correspond à "Ruby" à la fin d'une chaîne ou d'une ligne. |
3 | /\ARuby/ Correspond à "Ruby" au début d'une chaîne. |
4 | /Ruby\Z/ Correspond à "Ruby" à la fin d'une chaîne. |
5 | /\bRuby\b/ Correspond à "Ruby" à la limite d'un mot. |
6 | /\brub\B/ \ B n'est pas une limite de mot: correspond à "frotter" dans "rube" et "ruby" mais pas seul. |
sept | /Ruby(?=!)/ Correspond à "Ruby", s'il est suivi d'un point d'exclamation. |
8 | /Ruby(?!!)/ Correspond à "Ruby", s'il n'est pas suivi d'un point d'exclamation. |
N ° Sr. | Exemple et description |
---|---|
1 | /R(?#comment)/ Correspond à "R". Tout le reste est un commentaire. |
2 | /R(?i)uby/ Insensible à la casse tout en correspondant à "uby". |
3 | /R(?i:uby)/ Comme ci-dessus. |
4 | /rub(?:y|le))/ Regrouper uniquement sans créer une référence arrière \ 1. |
Rechercher et remplacer
Certaines des méthodes String les plus importantes qui utilisent des expressions régulières sont sub et gsub, et leurs variantes sur place sub! et gsub!.
Toutes ces méthodes effectuent une opération de recherche et de remplacement à l'aide d'un modèle Regexp. lesub & sub! remplace la première occurrence du motif et gsub & gsub! remplace toutes les occurrences.
le sub et gsub retourne une nouvelle chaîne, laissant l'original inchangé où comme sub! et gsub! modifiez la chaîne sur laquelle ils sont appelés.
Voici l'exemple -
#!/usr/bin/ruby
phone = "2004-959-559 #This is Phone Number"
# Delete Ruby-style comments
phone = phone.sub!(/#.*$/, "")
puts "Phone Num : #{phone}"
# Remove anything other than digits
phone = phone.gsub!(/\D/, "")
puts "Phone Num : #{phone}"
Cela produira le résultat suivant -
Phone Num : 2004-959-559
Phone Num : 2004959559
Voici un autre exemple -
#!/usr/bin/ruby
text = "rails are rails, really good Ruby on Rails"
# Change "rails" to "Rails" throughout
text.gsub!("rails", "Rails")
# Capitalize the word "Rails" throughout
text.gsub!(/\brails\b/, "Rails")
puts "#{text}"
Cela produira le résultat suivant -
Rails are Rails, really good Ruby on Rails