Heim > Artikel > Backend-Entwicklung > Warum ersetzt re.sub nicht alle Vorkommen durch re.MULTILINE?
Warum re.sub mit re.MULTILINE nicht alle Vorkommen ersetzt
Pythons re.sub-Funktion wurde entwickelt, um textbasierte Ersetzungen durchzuführen Bei regulären Ausdrücken wird es häufig mit dem re.MULTILINE-Flag verwendet, um das Übereinstimmungsverhalten des Caret-Zeichens (^) zu erweitern. Es kann jedoch zu einem unerwarteten Ergebnis kommen, wenn versucht wird, alle Vorkommen eines Musters mithilfe dieses Flags zu ersetzen.
Das Problem verstehen:
In der offiziellen Dokumentation für re.MULTILINE heißt es: dass es ermöglichen sollte, dass das Caret-Zeichen am Anfang jeder Zeile innerhalb einer Zeichenfolge übereinstimmt. Im folgenden Beispiel werden jedoch nicht alle Vorkommen von „//“ wie erwartet entfernt:
import re s = """// The quick brown fox. // Jumped over the lazy dog.""" result = re.sub('^//', '', s, re.MULTILINE) print(result)
Die Lösung:
Die Diskrepanz liegt in der Verwendung des re.MULTILINE-Flags. Standardmäßig wird das vierte Argument von re.sub als Anzahl und nicht als Flag interpretiert. Um dieses Problem zu beheben, kann man das Flags-Argument explizit verwenden, wie unten gezeigt:
result = re.sub('^//', '', s, flags=re.MULTILINE)
Alternativ kann der reguläre Ausdruck mit der Funktion re.compile vorkompiliert werden, um das Flag re.MULTILINE zu integrieren:
regex = re.compile('^//', re.MULTILINE) result = re.sub(regex, '', s)
Durch Angabe des Flags-Arguments oder Vorkompilierung des regulären Ausdrucks mit dem gewünschten Flag ersetzt die Funktion re.sub alle Vorkommen des Musters korrekt, unabhängig von Zeilenumbrüchen.
Das obige ist der detaillierte Inhalt vonWarum ersetzt re.sub nicht alle Vorkommen durch re.MULTILINE?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!