Quantifiers
Quantifizierer geben die Anzahl der Zeichen oder Ausdrücke an, die übereinstimmen sollen.
Probieren Sie es aus
const ghostSpeak = "booh boooooooh";
const regexpSpooky = /bo{3,}h/;
console.log(ghostSpeak.match(regexpSpooky));
// Expected output: Array ["boooooooh"]
const modifiedQuote = "[He] ha[s] to go read this novel [Alice in Wonderland].";
const regexpModifications = /\[.*?\]/g;
console.log(modifiedQuote.match(regexpModifications));
// Expected output: Array ["[He]", "[s]", "[Alice in Wonderland]"]
const regexpTooGreedy = /\[.*\]/g;
console.log(modifiedQuote.match(regexpTooGreedy));
// Expected output: Array ["[He] ha[s] to go read this novel [Alice in Wonderland]"]
Typen
Hinweis: Im Folgenden bezieht sich item nicht nur auf einzelne Zeichen, sondern schließt auch Zeichenklassen sowie Gruppen und Rückverweise ein.
Zeichen | Bedeutung |
---|---|
x*
|
Entspricht dem vorhergehenden Element "x" 0 oder mehrmals. Zum Beispiel
passt |
x+
|
Entspricht dem vorhergehenden Element "x" 1 oder mehrmals. Entspricht
|
x?
|
Entspricht dem vorhergehenden Element "x" 0 oder 1 Mal. Zum Beispiel
passt
Wenn es direkt nach einem der Quantifizierer |
x{n}
|
Wo "n" eine nicht-negative ganze Zahl ist, entspricht genau "n"
Vorkommen des vorhergehenden Elements "x". Zum Beispiel passt
|
x{n,}
|
Wo "n" eine nicht-negative ganze Zahl ist, entspricht mindestens "n"
Vorkommen des vorhergehenden Elements "x". Zum Beispiel passt
|
x{n,m}
|
Wo "n" und "m" nicht-negative ganze Zahlen sind und |
|
Standardmäßig sind Quantifizierer wie
|
Beispiele
Wiederholtes Muster
In diesem Beispiel matchen wir ein oder mehr Wortzeichen mit \w+
, dann ein oder mehr Zeichen "a" mit a+
und enden schließlich an einer Wortgrenze mit \b
.
const wordEndingWithAs = /\w+a+\b/;
const delicateMessage = "This is Spartaaaaaaa";
console.table(delicateMessage.match(wordEndingWithAs)); // [ "Spartaaaaaaa" ]
Zählen von Zeichen
In diesem Beispiel matchen wir Wörter, die einen einzelnen Buchstaben haben, Wörter, die zwischen 2 und 6 Buchstaben haben, und Wörter, die 13 oder mehr Buchstaben haben.
const singleLetterWord = /\b\w\b/g;
const notSoLongWord = /\b\w{2,6}\b/g;
const longWord = /\b\w{13,}\b/g;
const sentence = "Why do I have to learn multiplication table?";
console.table(sentence.match(singleLetterWord)); // ["I"]
console.table(sentence.match(notSoLongWord)); // [ "Why", "do", "have", "to", "learn", "table" ]
console.table(sentence.match(longWord)); // ["multiplication"]
Optionales Zeichen
In diesem Beispiel matchen wir Wörter, die entweder mit "our" oder "or" enden.
const britishText = "He asked his neighbour a favour.";
const americanText = "He asked his neighbor a favor.";
const regexpEnding = /\w+ou?r/g;
// \w+ One or several letters
// o followed by an "o",
// u? optionally followed by a "u"
// r followed by an "r"
console.table(britishText.match(regexpEnding));
// ["neighbour", "favour"]
console.table(americanText.match(regexpEnding));
// ["neighbor", "favor"]
Greedy versus Non-greedy
In diesem Beispiel matchen wir ein oder mehr Wortzeichen oder Leerzeichen mit [\w ]+
und [\w ]+?
. Der erste ist greedy und der zweite ist non-greedy. Beachten Sie, wie der zweite sofort stoppt, sobald er die minimale Anforderung erfüllt.
const text = "I must be getting somewhere near the center of the earth.";
const greedyRegexp = /[\w ]+/;
console.log(text.match(greedyRegexp)[0]);
// "I must be getting somewhere near the center of the earth"
// almost all of the text matches (leaves out the dot character)
const nonGreedyRegexp = /[\w ]+?/; // Notice the question mark
console.log(text.match(nonGreedyRegexp));
// "I"
// The match is the smallest one possible
Siehe auch
- Reguläre Ausdrücke Leitfaden
- Zeichenklassen Leitfaden
- Assertions Leitfaden
- Gruppen und Rückverweise Leitfaden
RegExp
- Reguläre Ausdrücke Referenz
- Quantifizierer:
*
,+
,?
,{n}
,{n,}
,{n,m}