[解決済み] 正規表現で重複するマッチを見つけるには?
2022-02-12 22:07:55
質問
>>> match = re.findall(r'\w\w', 'hello')
>>> print match
['he', 'll']
ということは、'he'と'll'は2文字ということになりますね。しかし、なぜ'el'と'lo'なのでしょうか? ではなく は正規表現にマッチするのでしょうか?
>>> match1 = re.findall(r'el', 'hello')
>>> print match1
['el']
>>>
解決方法は?
findall
は、デフォルトでは重複するマッチを生成しません。しかし、この式ではそうなります。
>>> re.findall(r'(?=(\w\w))', 'hello')
['he', 'el', 'll', 'lo']
ここで
(?=...)
は
ルックアヘッドアサーション
:
(?=...)
が一致する場合...
は次にマッチするが、その後に続く 文字列を使用します。これはルックアヘッドアサーションと呼ばれます。例えばIsaac (?=Asimov)
にマッチします。'Isaac '
が続く場合のみです。'Asimov'
.
関連
-
[解決済み】TypeError: re.findall()でバイトのようなオブジェクトに文字列パターンを使用することはできません。)
-
[解決済み] JavaScriptでメールアドレスを検証するのに最適な方法は何ですか?
-
[解決済み] 辞書を値で並べ替えるにはどうしたらいいですか?
-
[解決済み] リストを均等な大きさの塊に分割するには?
-
[解決済み] Python 3で「1000000000000000 in range(1000000000000001)」はなぜ速いのですか?
-
[解決済み] XHTMLの自己完結型タグを除くオープンタグにマッチするRegEx
-
[解決済み] Pandas DataFrameからカラムを削除する
-
[解決済み] JavaScriptの正規表現でマッチしたグループにアクセスするにはどうすればよいですか?
-
[解決済み] \0-9]よりも効率が悪い
-
[解決済み】2つの辞書を1つの式でマージする(辞書の和をとる)には?)
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
Pythonの非常に便利な2つのデコレーターを解説
-
PythonによるLeNetネットワークモデルの学習と予測
-
Python カメの描画コマンドとその例
-
PythonはWordの読み書きの変更操作を実装している
-
パッケージングツールPyinstallerの使用と落とし穴の回避
-
風力制御におけるKS原理を深く理解するためのpythonアルゴリズム
-
FacebookオープンソースワンストップサービスpythonのタイミングツールKats詳細
-
[解決済み】なぜ「LinAlgError: Grangercausalitytestsから「Singular matrix」と表示されるのはなぜですか?
-
[解決済み】Django: ImproperlyConfigured: SECRET_KEY 設定は空であってはならない
-
[解決済み】ValueError: pickleプロトコルがサポートされていません。3、python2 pickleはpython3 pickleでダンプしたファイルを読み込むことができない?