正規表現を使用して文字列内の単語全体を動的に照合するにはどうすればよいですか?
正規表現を使用して文字列内の単語全体を動的に一致させる
文字列内の単語全体を一致させるには、動的正規表現を利用できます。次のシナリオを考えてみましょう:
文内の単語はスペースで区切られていますが、句読点はどちらの側にも現れる場合があります。文字列の途中にある単語を識別するために、次のパターンは単語の部分一致を効果的に防止し、句読点を許可します:
match_middle_words = " [^a-zA-Z\d ]{0,}" + word + "[^a-zA-Z\d ]{0,} "
ただし、このパターンは、先頭または最後の単語が存在しないため、最初または最後の単語と一致しません。末尾のスペース。これに対処するために、追加のパターンを使用できます:
match_starting_word = "^[^a-zA-Z\d]{0,}" + word + "[^a-zA-Z\d ]{0,} " match_end_word = " [^a-zA-Z\d ]{0,}" + word + "[^a-zA-Z\d]{0,}$"
これらのパターンを組み合わせると、次の文字列が得られます:
match_string = match_middle_words + "|" + match_starting_word +"|" + match_end_word
このアプローチでは、単語が次の場合にのみキャプチャされることが保証されます。単語以外の文字で囲まれています。さらに、文字列の先頭と末尾の単語も処理します。
このプロセスを簡素化するために、b で示される 単語境界 を利用できます。これらの境界は文字列の先頭と末尾で一致するため、最初と最後の単語に別のパターンを使用する必要がなくなります。次のパターンは、単語全体と効率的に一致します:
match_string = r'\b' + word + r'\b'
このパターンは、単語のリストと一致するように簡単に変更できます:
words_list = ['word1', 'word2', 'word3'] match_string = r'\b(?:{})'.format('|'.join(words_list))
単語の境界を利用することで、3 つの単語の境界が不要になります。パターンを分離し、動的正規表現を使用して文字列内の単語全体を照合するプロセスを簡素化します。
以上が正規表現を使用して文字列内の単語全体を動的に照合するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











fiddlereveryversings for the-middleの測定値を使用するときに検出されないようにする方法

10時間以内にコンピューター初心者プログラミングの基本を教える方法は?コンピューター初心者にプログラミングの知識を教えるのに10時間しかない場合、何を教えることを選びますか...

Investing.comの反クラウリング戦略を理解する多くの人々は、Investing.com(https://cn.investing.com/news/latest-news)からのニュースデータをクロールしようとします。

Pythonasyncioについて...

Python 3.6のピクルスファイルの読み込みエラー:modulenotfounderror:nomodulenamed ...

SCAPYクローラーを使用するときにパイプラインファイルを作成できない理由についての議論は、SCAPYクローラーを学習して永続的なデータストレージに使用するときに、パイプラインファイルに遭遇する可能性があります...
