Java--正则表达式-简单的在字符串中找数字

import org.junit.Test;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class RegexTest {

    @Test
    public void test(){
        String line = "This order was placed for QT3000! OK?";
        String pattern = "\\d+";

        // Create a Pattern object
        Pattern r = Pattern.compile(pattern);

        // Now create matcher object.
        Matcher m = r.matcher(line);
        if (m.find( )) {
            System.out.println("Found value: " + m.group() );
        } else {
            System.out.println("NO MATCH");
        }
    }
}

 

其中\d+是匹配1个或者更多个数字。

最后输出结果为:3000

 

附上一张正则表达式元字符语法:

子表达式匹配对应
^匹配一行的开头
$匹配一行的结尾
.匹配除了换行符的任何单个字符,也可以利用 m 选项允许它匹配换行符
[...]匹配括号内的任意单个字符。
[^...]匹配不在括号内的任意单个字符。
\A整个字符串的开始
\z整个字符串的结束
\Z整个字符串的结束,除了最后一行的结束符
re*匹配0或者更多的前表达事件
re+匹配1个或更多的之前的事件
re?匹配0或者1件前表达事件
re{ n}匹配特定的n个前表达事件
re{ n,}匹配n或者更多的前表达事件
re{ n, m}匹配至少n最多m件前表达事件
a| b匹配a或者b
(re)正则表达式组匹配文本记忆
(?: re)没有匹配文本记忆的正则表达式组
(?> re)匹配无回溯的独立的模式
\w匹配单词字符
\W匹配非单词字符
\s匹配空格。等价于 [\t\n\r\f]
\S匹配非空格
\d匹配数字. 等价于 [0-9]
\D匹配非数字
\A匹配字符串的开始
\Z匹配字符串的末尾,如果存在新的一行,则匹配新的一行之前
\z匹配字符串的末尾
\G匹配上一次匹配结束的地方
\n返回参考捕获组号“N”
\b不在括号里时匹配单词边界。在括号里时匹配退格键
\B匹配非词边界
\n, \t, etc.匹配换行符,回车符,制表符,等
\Q引用字符的初始,结束于\E
\E结束由\Q开始的引用

转载于:https://www.cnblogs.com/eoss/p/5912805.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要判断一个字符串是否符合某种规则,可以使用 Java 正则表达式,以下是一些常用的元字符以及它们的含义: 1. ^ : 匹配字符串的开头 2. $ : 匹配字符串的结尾 3. . : 匹配任意单个字符 4. * : 匹配前一个字符的零次或多次出现 5. + : 匹配前一个字符的一次或多次出现 6. ? : 匹配前一个字符的零次或一次出现 7. [ ] : 匹配括号的任意一个字符 8. [^ ] : 匹配除了括号的任意一个字符以外的其他字符 9. ( ) : 将括号的表达式作为一个分组,方便后续引用 10. | : 匹配两个或多个表达式的任意一个 例如,要判断一个字符串是否为手机号码,可以使用以下的正则表达式: ```java String regex = "^1[3-9]\\d{9}$"; ``` 其,^ 表示字符串的开头,1 表示以数字 1 开头,[3-9] 表示第二个字符可以是 3-9 的任意一个,\\d 表示数字,{9} 表示数字出现 9 次,$ 表示字符串的结尾。 接着,使用 Java 的 Pattern 和 Matcher 类来对字符串进行匹配,示例如下: ```java String str = "13812345678"; String regex = "^1[3-9]\\d{9}$"; Pattern pattern = Pattern.compile(regex); Matcher matcher = pattern.matcher(str); if (matcher.matches()) { System.out.println("字符串符合规则"); } else { System.out.println("字符串不符合规则"); } ``` 上面的示例,首先定义了一个字符串 str 和一个正则表达式 regex,然后使用 Pattern 类的 compile 方法将正则表达式编译为一个模式 pattern,再使用 Matcher 类的 matcher 方法将模式和字符串进行匹配,最后根据匹配结果输出相应的提示信息。 ### 回答2: Java字符串正则表达式是一个非常重要的概念,它常用于判断字符串是否符合某种规则。而正则表达式的元字符,则是用来描述字符串的特性的,例如它是否是数字、字符、空格或者特殊符号等。 要判断一个字符串是否符合某种规则,需要使用Java的Pattern类和Matcher类来实现。以下是使用正则表达式判断字符串是否符合规则的基本步骤: 1. 首先,需要先使用Pattern类将正则表达式编译成一个Pattern对象。例如: ``` Pattern pattern = Pattern.compile("\\d{3}"); ``` 这里的正则表达式表示匹配三位数字。 2. 接着,要使用Matcher类的matches方法来匹配字符串。例如: ``` String str = "123"; Matcher matcher = pattern.matcher(str); if (matcher.matches()) { System.out.println("匹配成功"); } else { System.out.println("匹配失败"); } ``` 这里的matches方法会基于编译好的正则表达式对给定字符串进行匹配,并返回匹配结果。 在正则表达式,有一些元字符是常用的,例如\d表示匹配数字字符,\w表示匹配任意字母数字字符,. 表示匹配任意字符等。这些元字符可以帮助我们更方便地编写正则表达式,提高代码的可读性和维护性。 总之,学习Java字符串正则表达式以及元字符是十分重要的,它们可以用于验证用户输入、过滤特定字符等场景,帮助我们编写更健壮、高效的Java程序。 ### 回答3: 正则表达式是一种用于匹配字符串的工具,它可以用来在一段文本匹配出符合特定规则的字符串。在Java,使用Pattern和Matcher类来实现正则表达式的匹配功能。其,元字符是正则表达式的一种特殊字符,它们具有特殊的含义,可以用来描述字符串的模式。 对于Java字符串正则表达式,首先需要使用Pattern类来创建一个正则表达式模板,然后使用Matcher类来匹配字符串。在正则表达式,有一些常见的元字符,其最常用的是通配符"."和量词符"+"和"*"。通配符"."代表任意单个字符,而量词符"+"和"*"则分别代表至少出现一次和出现零次或多次。 对于判断字符串是否符合规则,可以使用Matcher类的matches()方法来进行匹配。例如,如果想要判断一个字符串是否符合邮箱格式,可以使用以下代码: ``` String email = "abc@test.com"; String regex = "\\w+@\\w+\\.\\w+"; Pattern pattern = Pattern.compile(regex); Matcher matcher = pattern.matcher(email); if (matcher.matches()) { System.out.println("符合规则"); } else { System.out.println("不符合规则"); } ``` 在上述代码,首先定义了一个字符串email和一个正则表达式模板regex,然后使用Pattern类创建一个正则表达式对象pattern,再使用Matcher类的matcher()方法创建一个匹配器matcher,最后使用matches()方法来进行匹配。如果字符串符合规则,则输出“符合规则”,否则输出“不符合规则”。 除了上述常见的元字符外,正则表达式还有许多其他的元字符,如字符组[...]、反向字符组[^...]、边界符^和$等等。在学习正则表达式的过程,需要不断练习和理解,才能熟练地运用它们来匹配字符串
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值