Go での否定後読みアサーションのシミュレーション
否定後読みアサーションは Go ではネイティブにサポートされていませんが、同様の結果を達成する代替方法があります。たとえば、「@」、「#」、または「/」などのプレフィックスを持つコマンドを除外しながら、「foo bar baz」のようなコマンドを抽出しようとする場合、否定的な後読みの代わりに否定された文字セットを利用できます。
たとえば、次の正規表現は、次の文字で始まらない単語に一致します:
\b[^@#/]\w.*
文字が文字列の先頭にも現れる場合は、 ^ アンカーを使用できます:
(?:^|[^@#\/])\b\w.*
別のアプローチには、フィルタ関数を利用して不要な単語を削除することが含まれます:
func Filter(vs []string, f func(string) bool) []string { vsf := make([]string, 0) for _, v := range vs { if f(v) { vsf = append(vsf, v) } } return vsf }
このフィルタを処理関数と組み合わせて単語を削除できます。以下に示すように、特定の接頭辞を使用して:
func Process(inp string) string { t := strings.Split(inp, " ") t = Filter(t, func(x string) bool { return strings.Index(x, "#") != 0 && strings.Index(x, "@") != 0 && strings.Index(x, "/") != 0 }) return strings.Join(t, " ") }
これらのフィルタリング手法を適用することで、Go での否定後読み動作をシミュレートし、効率的な処理を実現できます。特定のパターンのマッチングと抽出。
以上がGo で否定後読みアサーションをシミュレートするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。