用java 正则表达式 计算一个字符串中某个子串的个数

本文介绍如何使用Java的正则表达式和split方法来统计字符串中特定子串出现的次数,并提供了两种实现方式:一种利用Pattern和Matcher类进行不区分大小写的匹配;另一种直接采用split方法简化流程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

public class RegexTest {

    public static void main(String args[]){
        String str = "abcdfdfsabcdfdsf abc fdfdabcabc";

        //1. 用这则表达式处理, 不过好像一点都不省事.. 
        Pattern p = Pattern.compile("abc",Pattern.CASE_INSENSITIVE);
        Matcher m = p.matcher(str);
        int count = 0;
        while(m.find()){
              count ++;
        }
        System.out.println("ABC的个数 : " + count);

        //2. 用普通方法来做,比较省事
        String [] ary = ("," + str + ",").split("abc");
        System.out.println("ABC的个数 : " + (ary.length - 1));
    }
} 

我觉得用split方法,以"abc"做分隔符将字串拆分成数组,这样比较简单.不过上面的代码(第二种方法)只能判断小写"abc"的个数, 如果你还需要将"ABC"或者"aBc"或者"abC"这样的字串都找出来, 只需要将第二种方法的代码修改成下面这样的就可以了:

        String [] ary = ("," + str.toLowerCase() + ",").split("abc");
        System.out.println("ABC的个数 : " + (ary.length - 1));
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值