Skip to content

Commit 32fc82e

Browse files
authored
Merge pull request #198 from Aakodal/9.5-regexp-multiline-mode
Multiline mode of anchors ^ $, flag "m"
2 parents 1d8500d + ffbdc53 commit 32fc82e

File tree

1 file changed

+22
-26
lines changed
  • 9-regular-expressions/05-regexp-multiline-mode

1 file changed

+22
-26
lines changed
Lines changed: 22 additions & 26 deletions
Original file line numberDiff line numberDiff line change
@@ -1,14 +1,14 @@
1-
# Multiline mode of anchors ^ $, flag "m"
1+
# Mode multiligne des ancres ^ $, marqueur "m"
22

3-
The multiline mode is enabled by the flag `pattern:m`.
3+
Le mode multiligne est activé avec le marqueur `pattern:m`.
44

5-
It only affects the behavior of `pattern:^` and `pattern:$`.
5+
Il affecte seulement le fonctionnement des ancres `pattern:^` et `pattern:$`.
66

7-
In the multiline mode they match not only at the beginning and the end of the string, but also at start/end of line.
7+
Dans le mode multiligne, elles ne vérifient pas seulement le début et la fin d'une chaîne de caractères, mais également le début et la fin d'une ligne.
88

9-
## Searching at line start ^
9+
## Recherche au début de ligne ^
1010

11-
In the example below the text has multiple lines. The pattern `pattern:/^\d/gm` takes a digit from the beginning of each line:
11+
Dans l'exemple ci-dessous, le texte comporte plusieurs lignes. Le paterne `pattern:/^\d/gm` prend un chiffre au début de chaque ligne:
1212

1313
```js run
1414
let str = `1st place: Winnie
@@ -20,7 +20,7 @@ alert( str.match(/^\d/gm) ); // 1, 2, 3
2020
*/!*
2121
```
2222

23-
Without the flag `pattern:m` only the first digit is matched:
23+
Sans le marqueur `pattern:m`, seul le premier chiffre est renvoyé :
2424

2525
```js run
2626
let str = `1st place: Winnie
@@ -32,19 +32,17 @@ alert( str.match(/^\d/g) ); // 1
3232
*/!*
3333
```
3434

35-
That's because by default a caret `pattern:^` only matches at the beginning of the text, and in the multiline mode -- at the start of any line.
35+
Cela est dû au fait que, par défaut, l'accent circonflexe `pattern:^` ne vérifie que le début d'un texte, et dans le mode multiligne -- le début de n'importe quelle ligne.
3636

3737
```smart
38-
"Start of a line" formally means "immediately after a line break": the test `pattern:^` in multiline mode matches at all positions preceeded by a newline character `\n`.
39-
40-
And at the text start.
38+
"Début de ligne" désigne formellement "immédiatement après un saut à la ligne" : le test `pattern:^` en mode multiligne vérifie à toutes les positions suivant un caractère de retour à la ligne `\n`, en plus du début du texte.
4139
```
4240

43-
## Searching at line end $
41+
## Recherche en fin de ligne $
4442

45-
The dollar sign `pattern:$` behaves similarly.
43+
Le signe dollar `pattern:$` se comporte similairement.
4644

47-
The regular expression `pattern:\d$` finds the last digit in every line
45+
L'expression régulière `pattern:\d$` prend le premier chiffre à la fin de chaque ligne.
4846

4947
```js run
5048
let str = `Winnie: 1
@@ -54,21 +52,19 @@ Eeyore: 3`;
5452
alert( str.match(/\d$/gm) ); // 1,2,3
5553
```
5654

57-
Without the flag `m`, the dollar `pattern:$` would only match the end of the whole text, so only the very last digit would be found.
55+
Sans le marqueur `pattern:m`, le signe dollar `pattern:$` vérifierait uniquement la fin de tout le texte, donc uniquement le tout dernier chiffre serait trouvé.
5856

5957
```smart
60-
"End of a line" formally means "immediately before a line break": the test `pattern:$` in multiline mode matches at all positions succeeded by a newline character `\n`.
61-
62-
And at the text end.
58+
"Fin de ligne" désigne formellement "immédiatement avant un saut à la ligne" : le test `pattern:$` en mode multiligne vérifie à toutes les positions précédant un caractère de retour à la ligne `\n`, en plus de la fin du texte.
6359
```
6460

65-
## Searching for \n instead of ^ $
61+
## Recherche de \n au lieu de ^ $
6662

67-
To find a newline, we can use not only anchors `pattern:^` and `pattern:$`, but also the newline character `\n`.
63+
Pour chercher un retour à la ligne, nous pouvons non seulement utiliser les ancres `pattern:^` et `pattern:$`, mais également le caractère de retour à la ligne `\n`.
6864

69-
What's the difference? Let's see an example.
65+
Quelle est la différence ? Regardons un exemple.
7066

71-
Here we search for `pattern:\d\n` instead of `pattern:\d$`:
67+
Ici, nous cherchons `pattern:\d\n` au lieu de `pattern:\d$`:
7268

7369
```js run
7470
let str = `Winnie: 1
@@ -78,10 +74,10 @@ Eeyore: 3`;
7874
alert( str.match(/\d\n/gm) ); // 1\n,2\n
7975
```
8076

81-
As we can see, there are 2 matches instead of 3.
77+
Comme nous pouvons le voir, il y a 2 correspondances au lieu de 3.
8278

83-
That's because there's no newline after `subject:3` (there's text end though, so it matches `pattern:$`).
79+
C'est parce qu'il n'y a pas de retour à la ligne après `subject:3` (il y a la fin du texte cependant, donc ça correspond avec `pattern:$`).
8480

85-
Another difference: now every match includes a newline character `match:\n`. Unlike the anchors `pattern:^` `pattern:$`, that only test the condition (start/end of a line), `\n` is a character, so it becomes a part of the result.
81+
Une autre différence : maintenant, chaque correspondance inclue un caractère de retour à la ligne `match:\n`. Contrairement aux ancres `pattern:^` `pattern:$`, qui ne testent qu'une condition (début/fin d'une ligne), `\n` est un caractère, donc il devient une partie du résultat.
8682

87-
So, a `\n` in the pattern is used when we need newline characters in the result, while anchors are used to find something at the beginning/end of a line.
83+
Ainsi, un `\n` dans le paterne est utilisé quand nous avons besoin dudit caractère dans le résultat, tandis que les ancres sont utilisées pour chercher quelque chose au début/à la fin d'une ligne.

0 commit comments

Comments
 (0)