Heim >Backend-Entwicklung >Python-Tutorial >Warum ersetzt „re.sub' nicht alle Vorkommen durch „re.MULTILINE'?
Pythons re.sub mit re.MULTILINE-Flag kann nicht alle Vorkommen ersetzen
Die Python-Dokumentation gibt an, dass das re.MULTILINE-Flag, wenn angegeben, ermöglicht die Übereinstimmung des „^“-Musters am Anfang der Zeichenfolge und am Anfang jeder Zeile. Allerdings tritt ein verwirrendes Verhalten auf, wenn dieses Flag mit re.sub verwendet wird.
Beachten Sie den folgenden Code:
<code class="python">import re s = """// The quick brown fox. ... // Jumped over the lazy dog.""" print(re.sub('^//', '', s, re.MULTILINE))</code>
Dieser Code soll alle Vorkommen des Kommentars „//“ entfernen am Anfang jeder Zeile. Die Ausgabe lässt jedoch unerwarteterweise ein Vorkommnis unberührt:
The quick brown fox. // Jumped over the lazy dog.
Verstehen des Problems
Die Ursache für dieses Verhalten liegt in der falschen Verwendung des vierten Arguments im re.sub-Funktion. Dieses Argument dient zur Angabe der Anzahl der zu ersetzenden Übereinstimmungen und nicht als Flag. Im angegebenen Code wird re.MULTILINE (mit dem Wert 8) als Zählung und nicht als Flag verwendet.
Korrektur des Codes
An Um das Problem zu lösen, gibt es zwei mögliche Ansätze:
<code class="python">print(re.sub('^//', '', s, flags=re.MULTILINE))</code>
<code class="python">print(re.sub(re.compile('^//', re.MULTILINE), '', s))</code>
Beide Methoden verwenden re korrekt. MULTILINE als Flag, was zum gewünschten Verhalten führt:
The quick brown fox. Jumped over the lazy dog.
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!