import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class $ {
public static void main(String[] args) {
String regex = "[A-Za-z]{0,}[C|c][O|o][M|m][E|e][A-Za-z]{0,}[,| |!]";
String str = "hello,world!Welcome to our house!Come on,we may be late!";
Matcher m = Pattern.compile(regex).matcher(str);
while (m.find()) {
System.out.println(m.group());
}
}
}
你这里麻烦的就是不区分come的大小写。看这个正则表达式
[A-Za-z]{0,}[C|c][O|o][M|m][E|e][A-Za-z]{0,}[,| |!]
[A-Za-z]{0,} 表示0个或者多个大写或者小写字母组合;
[C|c][O|o][M|m][E|e] 表示 come的任何大小写组合;
[A-Za-z]{0,} 同1;
[,| |!] 表示结束的字符是逗号、空格、叹号;
这样的字母组合是你希望得到的。
如果不能满足你的要求,根据这个规律,你自行修改下
使用正则表达式呀,这种场景最适合用正则了。
刚好可以补充一下正则的知识
首先根据空格和标点将字符串分割成单词列表存起来,然后依次查找含有come的单词就行了
查一下正则表达式,它因该可以解决你的问题