Java 正则表达式高级用法

本文涉及的产品
多模态交互后付费免费试用,全链路、全Agent
简介: 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 类以及各类高级功能(如断言、捕获组、命名组、替换、分割等),可以高效地进行文本匹配和处理。熟练掌握正则表达式对于处理复杂的文本数据有很大帮助。

相关文章
|
11天前
|
数据采集 数据可视化 安全
最详细Java正则表达式详解
本文系统讲解Java正则表达式核心语法、API用法及性能优化技巧,结合代码示例与实战场景,助你掌握文本处理利器,提升开发效率。
189 0
|
1月前
|
Java 编译器 API
Java Lambda表达式与函数式编程入门
Lambda表达式是Java 8引入的重要特性,简化了函数式编程的实现方式。它通过简洁的语法替代传统的匿名内部类,使代码更清晰、易读。本文深入讲解Lambda表达式的基本语法、函数式接口、方法引用等核心概念,并结合集合操作、线程处理、事件回调等实战案例,帮助开发者掌握现代Java编程技巧。同时,还解析了面试中高频出现的相关问题,助你深入理解其原理与应用场景。
|
1月前
|
安全 Java API
Java中的Lambda表达式:简洁与功能的结合
Java中的Lambda表达式:简洁与功能的结合
348 211
|
1月前
|
安全 Java
Java中的Switch表达式:更简洁的多路分支
Java中的Switch表达式:更简洁的多路分支
400 211
|
1月前
|
Java 编译器
Java 17 Switch表达式:更简洁、更强大的流程控制
Java 17 Switch表达式:更简洁、更强大的流程控制
|
2月前
|
设计模式 数据采集 Java
Java正则表达式的基础知识,进阶至熟练掌握。
通过大量的练习来熟悉它们的识别模式、如何设计模式来解决实际问题,才能够逐步达到熟练掌握。更多的是通过实践、编写代码和解决真实问题来完善技能。在这方面,没有快速的捷径,唯有刻意练习和长时间的代码实践。
70 0
|
2月前
|
自然语言处理 Java Apache
在Java中将String字符串转换为算术表达式并计算
具体的实现逻辑需要填写在 `Tokenizer`和 `ExpressionParser`类中,这里只提供了大概的框架。在实际实现时 `Tokenizer`应该提供分词逻辑,把输入的字符串转换成Token序列。而 `ExpressionParser`应当通过递归下降的方式依次解析
215 14
|
3月前
|
SQL JSON 安全
Java 8 + 中 Lambda 表达式与 Stream API 的应用解析
摘要:本文介绍了Java 8+核心新特性,包括Lambda表达式与Stream API的集合操作(如过滤统计)、函数式接口的自定义实现、Optional类的空值安全处理、接口默认方法与静态方法的扩展能力,以及Java 9模块化系统的组件管理。每个特性均配有典型应用场景和代码示例,如使用Stream统计字符串长度、Optional处理Map取值、模块化项目的依赖声明等,帮助开发者掌握现代Java的高效编程范式。(150字)
72 1
|
5月前
|
Java 编译器 API
Java Lambda 表达式:以 Foo 接口为例深入解析
本文深入解析了 Java 8 中 Lambda 表达式的用法及其背后的函数式接口原理,以 `Foo` 接口为例,展示了如何通过简洁的 Lambda 表达式替代传统匿名类实现。文章从 Lambda 基本语法、函数式接口定义到实际应用层层递进,并探讨默认方法与静态方法的扩展性,最后总结常见误区与关键点,助你高效优化代码!
126 0