Java で正規表現を使用する方法

WBOY
リリース: 2023-06-15 21:14:28
オリジナル
2888 人が閲覧しました

Java は、文字列処理の効率を向上させる強力な正規表現ツールを提供する人気のあるプログラミング言語です。正規表現は文字列のセットを記述するパターンであり、パターン マッチング、検索、置換操作の実行に使用できます。次の記事では、Java で正規表現を使用する方法を学習します。

  1. 正規表現構文

Java の正規表現は、Perl 言語の正規表現構文に基づいており、Java 固有の構文がいくつか含まれています。正規表現は文字と特殊文字で構成されます。特殊文字は意味が異なります。一般的に使用される特殊文字とその意味を次に示します。

  • ^: 文字列の先頭と一致します
  • $: 文字列
  • の末尾と一致します。 : 改行文字を除く任意の 1 文字と一致します
  • d: 数字と一致します
  • D: 数字以外の文字と一致します
  • s: スペース文字と一致します
  • S: スペース以外の文字と一致します
  • w: 文字、数字、またはアンダースコア文字と一致します
  • W: 文字、数字、またはアンダースコア文字以外の文字と一致します
  • []:角括弧内の任意の文字と一致します
  • [^]: 角括弧内にない任意の文字と一致します
  • (): 一致する部分式を区別するためのキャプチャ グループを作成します
  • |:論理和演算文字。いずれかの式と一致します。
  • *: 0 個以上の隣接する文字と一致します。
  • : 1 つ以上の隣接する文字と一致します。
  • ?: 0 個または 1 個の隣接する文字と一致します。文字
  • {n}: n 個の隣接する文字と一致します
  • {n,}: n 個以上の隣接する文字と一致します
  • { n,m}: n ~ m 個の隣接する文字と一致します
  1. Java の正規表現クラス

Java には、Pattern と Matcher という 2 つの主要な正規表現 Expression クラスが用意されています。 Pattern クラスは正規表現をコンパイルして Pattern オブジェクトを返すために使用され、Matcher クラスは照合操作を実行するために使用されます。

Pattern クラスのcompile() メソッドを使用して正規表現をコンパイルし、Pattern オブジェクトを返します。次に、Pattern オブジェクトの matcher() メソッドを使用して Matcher オブジェクトを作成し、Matcher オブジェクトのメソッドを呼び出してマッチング操作を実行します。以下は簡単な例です:

String patternString = "hello";
String testString = "Hello, world!";
Pattern pattern = Pattern.compile(patternString);
Matcher matcher = pattern.matcher(testString);
boolean matches = matcher.matches();
System.out.println(matches); // false
ログイン後にコピー

上の例では、文字列「hello」に一致する Pattern オブジェクトを作成し、次にその Pattern オブジェクトを使用して文字列「Hello,」に一致する Matcher オブジェクトを作成しました。世界!"。文字列内の文字が正規表現と正確に一致しないため、matches() メソッドは false を返します。

matcher クラスは、matches() メソッドに加えて、次のような他のメソッドも提供します。

  • find(): 次の一致を検索します。
  • group( ): キャプチャ グループ内の一致結果を返します
  • start(): 一致の開始インデックスを返します
  • end(): 一致の終了インデックスを返します
  1. 正規表現の使用シナリオ

Java では、正規表現には次のような幅広いアプリケーション シナリオがあります。

  • 入力データ形式の検証: などメールアドレスや電話番号の認証として 数字やURLなどの形式は正しいですか?
  • データの抽出: たとえば、テキストから URL、電話番号、郵便番号、その他のデータを抽出します。
  • データの置換: たとえば、テキスト内の特定のキーワードを他のコンテンツに置き換えます。
  • テキストの検索: たとえば、テキスト エディターで何かを検索します。
  • データのフィルター: たとえば、ログ ファイルから特定のレコードをフィルターで除外します。
  1. 注意事項

正規表現は Java で広く使用されていますが、使用する際には注意が必要な点がいくつかあります。例:

  • 正規表現は理解や維持が難しい場合があるため、まずオンラインの正規表現テスト ツール (regex101.com、regexr.com など) を使用して練習とデバッグを行うことができます。
  • 複雑な正規表現を処理すると、バックトラッキングの問題が発生し、一致時間が非常に長くなる可能性があります。この場合、後戻りを避けるために遅延または事前検索を使用できます。
  • 大規模なテキストの検索や置換など、一部の特定のシナリオでは、処理効率が影響を受ける可能性があります。効率を向上させるために、Apache Lucene などの正規表現関連のライブラリを使用できます。

概要

正規表現は、文字列を処理する際の効率を向上させる強力なツールです。 Java では、Pattern クラスと Matcher クラスを使用して正規表現をコンパイルし、実行できます。正規表現を使用する場合は、正しい一致を保証し、効率を向上させるために、正規表現の構文と注意事項に注意する必要があります。

以上がJava で正規表現を使用する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート