Java 正则表达式高级用法

简介: Java 中的正则表达式是强大的文本处理工具,用于搜索、匹配、替换和分割字符串。`java.util.regex` 包提供了 `Pattern` 和 `Matcher` 类来高效处理正则表达式。本文介绍了高级用法,包括使用 `Pattern` 和 `Matcher` 进行匹配、断言(如正向和负向前瞻/后顾)、捕获组与命名组、替换操作、分割字符串、修饰符(如忽略大小写和多行模式)及 Unicode 支持。通过这些功能,可以高效地处理复杂文本数据。

Java 中的正则表达式(Regular Expressions)是强大的文本处理工具,可以用于搜索、匹配、替换和分割字符串。Java 提供了 java.util.regex 包来支持正则表达式的使用。以下是一些 Java 正则表达式的高级用法。

1. 使用 PatternMatcher

在 Java 中,正则表达式的使用通常涉及到 PatternMatcher 类。这两个类使得正则表达式的编译和匹配过程更为高效。

import java.util.regex.Pattern;
import java.util.regex.Matcher;

String input = "Hello, my email is example@example.com";
String regex = "\\w+@\\w+\\.com";

Pattern pattern = Pattern.compile(regex);
Matcher matcher = pattern.matcher(input);

while (matcher.find()) {
   
    System.out.println("找到的邮箱: " + matcher.group());
}

2. 断言(Assertions)

正则表达式中的断言用于匹配某些条件但不包括这些条件的字符。常见的断言有:

  • 正向前瞻(Positive Lookahead) (?=...)
  • 负向前瞻(Negative Lookahead) (?!...)
  • 正向后顾(Positive Lookbehind) (?<=...)
  • 负向后顾(Negative Lookbehind) (?<!...)

示例:匹配包含数字的单词,但不包含数字。

String input = "abc1 def2 ghi";
String regex = "\\b(?=\\w*)(?<!\\d)\\w+\\b";

Pattern pattern = Pattern.compile(regex);
Matcher matcher = pattern.matcher(input);

while (matcher.find()) {
   
    System.out.println("匹配的单词: " + matcher.group());
}

3. 捕获组和命名组

捕获组用于提取匹配到的部分,命名组可以提高可读性。

捕获组

String input = "My name is John and I am 30 years old.";
String regex = "name is (\\w+) and I am (\\d+)";

Pattern pattern = Pattern.compile(regex);
Matcher matcher = pattern.matcher(input);

if (matcher.find()) {
   
    System.out.println("姓名: " + matcher.group(1)); // John
    System.out.println("年龄: " + matcher.group(2)); // 30
}

命名组

String input = "My name is John and I am 30 years old.";
String regex = "name is (?<name>\\w+) and I am (?<age>\\d+)";

Pattern pattern = Pattern.compile(regex);
Matcher matcher = pattern.matcher(input);

if (matcher.find()) {
   
    System.out.println("姓名: " + matcher.group("name")); // John
    System.out.println("年龄: " + matcher.group("age")); // 30
}

4. 替换操作

使用 Matcher 可以进行文本的替换。

String input = "The quick brown fox jumps over the lazy dog.";
String regex = "brown";
String replacement = "black";

String result = input.replaceAll(regex, replacement);
System.out.println("替换后的字符串: " + result); // The quick black fox jumps over the lazy dog.

5. 分割字符串

使用正则表达式来分割字符串。

String input = "apple, banana; orange: melon";
String regex = "[,;:]\\s*"; // 逗号、分号、冒号及其后可选空格

String[] fruits = input.split(regex);
for (String fruit : fruits) {
   
    System.out.println(fruit);
}

6. 使用修饰符

可以使用修饰符来修改正则匹配的行为,例如:

  • Pattern.CASE_INSENSITIVE: 忽略大小写
  • Pattern.MULTILINE: 多行模式

例如:

String input = "Hello World\nhello world";
String regex = "hello";

Pattern pattern = Pattern.compile(regex, Pattern.CASE_INSENSITIVE | Pattern.MULTILINE);
Matcher matcher = pattern.matcher(input);

while (matcher.find()) {
   
    System.out.println("找到的匹配: " + matcher.group());
}

7. Unicode 支持

Java 正则表达式支持 Unicode 字符,可以用于匹配国际化文本。

String input = "你好,世界";
String regex = "\\p{Han}+"; // 匹配汉字

Pattern pattern = Pattern.compile(regex);
Matcher matcher = pattern.matcher(input);

while (matcher.find()) {
   
    System.out.println("找到的中文: " + matcher.group());
}

总结

Java 正则表达式提供了非常强大的文本处理能力,通过使用 PatternMatcher 类以及各类高级功能(如断言、捕获组、命名组、替换、分割等),可以高效地进行文本匹配和处理。熟练掌握正则表达式对于处理复杂的文本数据有很大帮助。

相关文章
|
5天前
|
Java
探索Java中的Lambda表达式
【10月更文挑战第37天】本文将带你深入理解Java的Lambda表达式,从基础语法到高级特性,通过实例讲解其在函数式编程中的应用。我们还将探讨Lambda表达式如何简化代码、提高开发效率,并讨论其在实际项目中的应用。
|
7天前
|
Java API
Java中的Lambda表达式与函数式编程####
【10月更文挑战第29天】 本文将深入探讨Java中Lambda表达式的实现及其在函数式编程中的应用。通过对比传统方法,我们将揭示Lambda如何简化代码、提高可读性和维护性。文章还将展示一些实际案例,帮助读者更好地理解和应用Lambda表达式。 ####
|
7天前
|
JSON 自然语言处理 Java
这款轻量级 Java 表达式引擎,真不错!
AviatorScript 是一个高性能、轻量级的脚本语言,基于 JVM(包括 Android 平台)。它支持数字、字符串、正则表达式、布尔值等基本类型,以及所有 Java 运算符。主要特性包括函数式编程、大整数和高精度运算、完整的脚本语法、丰富的内置函数和自定义函数支持。适用于规则判断、公式计算、动态脚本控制等场景。
|
12天前
|
Java API 开发者
Java中的Lambda表达式与函数式编程####
在Java的演变过程中,Lambda表达式和函数式编程的引入无疑是一次重大的飞跃。本文将深入探讨Lambda表达式的定义、用法及优势,并结合实例说明如何在Java中利用Lambda表达式进行函数式编程。通过对比传统编程方式,揭示Lambda表达式如何简化代码、提高开发效率和可维护性。 ####
|
21天前
|
自然语言处理 安全 Java
Aviator Java 表达式引擎
AviatorScript 是一门高性能、轻量级寄宿于 JVM 之上的脚本语言。
40 10
|
18天前
|
Java API 数据处理
探索Java中的Lambda表达式与Stream API
【10月更文挑战第22天】 在Java编程中,Lambda表达式和Stream API是两个强大的功能,它们极大地简化了代码的编写和提高了开发效率。本文将深入探讨这两个概念的基本用法、优势以及在实际项目中的应用案例,帮助读者更好地理解和运用这些现代Java特性。
|
22天前
|
存储 安全 Java
深入理解Java中的FutureTask:用法和原理
【10月更文挑战第28天】`FutureTask` 是 Java 中 `java.util.concurrent` 包下的一个类,实现了 `RunnableFuture` 接口,支持异步计算和结果获取。它可以作为 `Runnable` 被线程执行,同时通过 `Future` 接口获取计算结果。`FutureTask` 可以基于 `Callable` 或 `Runnable` 创建,常用于多线程环境中执行耗时任务,避免阻塞主线程。任务结果可通过 `get` 方法获取,支持阻塞和非阻塞方式。内部使用 AQS 实现同步机制,确保线程安全。
|
1月前
|
Java 数据库
案例一:去掉数据库某列中的所有英文,利用java正则表达式去做,核心:去掉字符串中的英文
这篇文章介绍了如何使用Java正则表达式从数据库某列中去除所有英文字符。
46 15
|
22天前
|
Java API
[Java]Lambda表达式
本文主要介绍了Java中的Lambda表达式,包括其优化匿名内部类的方式、使用规范、内置函数式接口及方法引用等内容。文章详细解析了Lambda的基础语法、参数列表、方法体的简化规则,以及如何利用Lambda优化代码。此外,还探讨了Lambda的作用域和引用规则,强调了对局部变量、成员变量和常量的访问限制,旨在帮助读者全面理解和掌握Lambda表达式的应用。
13 0
[Java]Lambda表达式
|
1月前
|
Java 程序员 API
Java中的Lambda表达式:简化代码的秘密武器
【10月更文挑战第11天】 在Java编程中,Lambda表达式是一种简洁而强大的工具,它允许我们将函数作为参数传递给其他方法。本文将介绍Lambda表达式的基本概念、使用方法以及在实际项目中的应用案例,帮助你更好地理解和利用这一特性来简化代码。
22 8