Python 3 では、多数の文字列に対して正規表現ベースの置換を実行するのは、時間のかかるプロセスになる可能性があります。この記事では、単語の境界でのみ置換を行う必要があるシナリオで、このような操作の効率を高める 2 つの方法を検討します。
str を使用する。 replace メソッドは、 re.sub よりもパフォーマンスが向上する可能性があります。置換が確実に単語境界に限定されるようにするには、replace メソッド内で b メタキャラクタを利用します。例:
import string # Create a list of common English stop words stop_words = set(line.strip() for line in open('stop_words.txt')) # Define a function for replacing stop words def replace_stop_words(text): # Generate pattern by escaping each stop word with \b metacharacter pattern = r'\b' + string.join(['\b%s\b' % word for word in stop_words]) + r'\b' # Perform the replacement using str.replace return text.replace(pattern, '')
置換プロセスを高速化するもう 1 つのアプローチには、トライを利用することが含まれます。トライは、禁止用語リスト。トライの構造により、効率的なマッチングが可能になり、パフォーマンスが大幅に向上します。
import trie # Initialize the trie trie = trie.Trie() # Add banned words to the trie for word in banned_words: trie.add(word)
# Obtain the regular expression banned_words_pattern = r"\b" + trie.pattern() + r"\b"
# Perform the replacement using re.sub for sentence in sentences: sentence = sentence.replace(banned_words_pattern, '')
どちらの方法でも、パフォーマンス上の利点が得られる可能性があります。選択は、特定の要件と禁止単語リストのサイズによって異なります。比較的小さなリストの場合は、str.replace を使用した単語境界置換アプローチで十分な場合があります。ただし、禁止単語リストが大きい場合は、トライベースの方法を使用すると、実行時間が大幅に短縮される可能性があります。
以上が速度を上げるために、特に単語の境界で Python の正規表現置換を最適化するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。