学习-Java字符串之正则表达式之元字符之判断字符串是否符合规则

第1关:学习-Java字符串之正则表达式之元字符之判断字符串是否符合规则

任务描述

本关任务:接收给定的字符串,如果该字符串同时符合以下要求,请输出该字符串。 1.字符串由三个字符组成; 2.字符串以数字开头; 3.字符串以小写字母结束。

相关知识
正则表达式的概念

正则表达式,又称规则表达式,计算机科学的一个概念。正则表达式通常被用来检索、替换那些符合某个模式(规则)的文本。

我们可以使用正则表达式^\d+b$可以匹配到如下所有字符串:

 
  1. 23sb、32run4oob、2oo32ooob

其中正则表达式中的\d属于正则表达式中的元字符,代表 0-9 中的任意一个数字。+^$属于正则表达式中的限定修饰符,+代表一个或者多个,^代表开始位置,$代表结束位置。所以该正则表达式中可以匹配到以数字开头,以字母 b 结尾的所有字符串。 #####正则表达式中的元字符

元字符正则表达式中的写法意义
..代表任意一个字符
\d\d代表0-9的任何一个数字
\D\D代表任何一个非数字字符
\s\s代表空白字符,如‘\t’,'\n'
\S\S代表非空白字符
^^匹配字符串的开始
$$匹配字符串的结束
x|yx|y匹配 x 或 y。例如,'z|food' 能匹配 "z" 或 "food"。'(z|f)ood' 则匹配 "zood" 或 "food"
[xyz][xyz]字符集合。匹配所包含的任意一个字符。例如, '[abc]' 可以匹配 "plain" 中的 'a'
[a-z][a-z]字符范围,匹配指定范围内的任意字符。例如,'[a-z]' 可以匹配 'a' 到 'z' 范围内的任意小写字母字符
[^a-z][^a-z]负值字符范围,匹配任何不在指定范围内的任意字符。例如,'[^a-z]' 可以匹配任何不在 'a' 到 'z' 范围内的任意字符
\w\w匹配字母、数字、下划线。等价于'[A-Za-z0-9_]'
\W\W匹配非字母、数字、下划线。等价于 '[^A-Za-z0-9_]'
String 类中正则表达式的应用

1.matches() 方法:判断字符串是否匹配正则表达式。

 
  1. String str="8sA";
  2. boolean matches = str.matches("\\d[a-z][A-Z]"); // 判断字符串是否匹配正则表达式,其中代表任意数字的\d用在代码中需要使用转义符\。
  3. System.out.println(matches);

执行结果:

 
  1. true

2.split() 方法:根据正则表达式切割字符串。

 
  1. String str="sA-sA";
  2. // 根据正则表达式切割字符串
  3. String[] split = str.split("-");
  4. System.out.print(split);

执行结果:

 
  1. [sA,sA]

3.replaceAll() 方法:替换符合正则表达式的字符串内容。

 
  1. String str="sA-sA";
  2. // 替换符合正则表达式的字符串内容
  3. String s = str.replaceAll("[a-z]", "123");
  4. System.out.print(s);

执行结果:

 
  1. 123A-123A
编程要求

仔细阅读右侧编辑区内给出的代码框架及注释,按照提示编写程序代码。

测试说明

平台将使用测试集运行你编写的程序代码,若全部的运行结果正确,则通关。

可在右侧 “测试结果”区查看具体的测试集详情。 例: 测试输入:

 
  1. sssss9098djhshduew

预期输出

 
  1. sssss9098djhshduew不符合给定规则

测试输入:

 
  1. 0ww

预期输出

 
  1. 0ww

开始你的任务吧,祝你成功!

源代码:

import java.util.Scanner;

public class StrTest {

    public static void main(String[] args) {
// 请在Begin-End间编写代码
/********** Begin **********/

// 第一步:接收给定的字符串
Scanner input = new Scanner(System.in);
        String str = input.next();
// 第二步:判断给定的字符串是否符合给定的规则,符合的话请输出该字符串
int length = str.length();
        boolean matches = str.matches("^\\d+[a-z]+$");
        if (length == 3 && matches == true){
            System.out.println(str);
// 第三步:不符合的话请输出该字符串不符合规则
}else {
            System.out.println(str + "不符合给定规则");
        }
/********** End **********/

    }
}

  • 5
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值