re モジュールの正規表現は単語境界 (b) をサポートしますか?
単語境界に一致させるために b エスケープ シーケンスを使用しようとしているときPython の re モジュールでは不整合が発生する可能性があります。次のコード スニペットはこれを示しています。
>>> x = 'one two three' >>> y = re.search("\btwo\b", x)
驚くべきことに、予期された一致オブジェクトが存在せず、代わりに None が返されます。これにより、Python が b 式をサポートしているのか、それともその使用法が間違っているのかという疑問が生じます。
この不一致は、コード内で通常の文字列が使用されていることが原因です。以下に示すように、代わりに生の文字列を使用する必要があります。
>>> x = 'one two three' >>> y = re.search(r"\btwo\b", x)
この変更により問題が解決され、意図したとおりの一致オブジェクトが得られます。
さらに、次のアプローチの使用を検討してください。
word = 'two' re.compile(r'\b%s\b' % word, re.I)
これにより、大文字と小文字を区別しない一致が保証され、成功する一致の範囲が拡大する可能性があります。
以上がPython の「re」モジュールは正規表現の単語境界 (「\b」) を正しく処理しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。