大小写不敏感的Java查找替代

简介:

方法可以采用正则表达在想要搜索的字符串前边构造(?i),表示大小写不敏感。例如,要搜索here,则构造(?i)here,表示here,Here,HERE等。但是这还会匹配there,我们还可以加上字符间隔符来表示一个单独的here单词, /b(?i)here/b。 使用String的matches( ) 方法进行匹配。replaceAll()方法则是用来进行替换的。

以上两个方法注意处理异常。下边的小例子就忽略这个了。

// Ignore case differences when searching for 
// or replacing substrings. 
class IgnoreCaseDemo { 
  public static void main(String args[]) { 
    String str = "This is a TEST."; 
    System.out.println("Ignore case when searching./n" + 
                       "Looking for 'test' in: " + str); 
    // Use matches() to find any version of test. 
    if(str.matches("(?i).*test.*")) 
      System.out.println("test is in the string."); 
    System.out.println(); 
    str = "alpha beta, Alpha beta, alPHa beta, ALPHA beta";

    // Use replaceAll() to ignore case when replacing one 
    // substring with another. 
    // In this example, replace all versions of alpha with zeta. 
    System.out.println("Ignore case when replacing./n" + 
                       "Replace any version of 'alpha' " + 
                       "with 'zeta' in:/n" + "   " + str); 
    String result = str.replaceAll("(?i)alpha", "zeta"); 
    System.out.println("After replacement:/n" + 
                       "   " + result); 
  } 
}

当然这并不是唯一的方法, regionMatches( ) 方法也可以使用。要是不嫌麻烦,也可以先将字符串转化为小写,然后用contains()方法确定是不是存在子字符串。

在替代的时候,要是想替代第一次出现的,则使用 replaceFirst( )方法。

 




本文转自gnuhpc博客园博客,原文链接:http://www.cnblogs.com/gnuhpc/archive/2012/12/17/2822343.html,如需转载请自行联系原作者

相关文章
Java基础数组-元素暴力查找方法
Java基础数组-元素暴力查找方法
Java基础数组-元素暴力查找方法
|
算法 Java
二维数组中的查找(Java实现)
二维数组中的查找(Java实现)
84 0
|
存储 Java 数据挖掘
Java基础知识练习(减肥计划、逢七过、不死神兔、百钱百鸡、数组元素求和、数组内容相同、查找、反转、评委打分)
Java基础知识练习(减肥计划、逢七过、不死神兔、百钱百鸡、数组元素求和、数组内容相同、查找、反转、评委打分)!
Java基础知识练习(减肥计划、逢七过、不死神兔、百钱百鸡、数组元素求和、数组内容相同、查找、反转、评委打分)
|
Java
java学习第十一天笔记-字符串217-根据id查找用户信息
java学习第十一天笔记-字符串217-根据id查找用户信息
61 0
java学习第十一天笔记-字符串217-根据id查找用户信息
|
存储 Java
(Java)数据结构之树与二叉树(二叉树的四种遍历,获取结点个数,获取叶子结点个数,获取高度,获取第k层结点个数,查找值为val的结点,判断一棵树是否为完全二叉树(详述,图文并茂)
树是一种非线性的数据结构,它是由n个(n>=0)个有限节点组成一个具有层次关系的集合。它的形状像一颗倒挂的树,根在上,叶在下。
(Java)数据结构之树与二叉树(二叉树的四种遍历,获取结点个数,获取叶子结点个数,获取高度,获取第k层结点个数,查找值为val的结点,判断一棵树是否为完全二叉树(详述,图文并茂)
|
Java Go Python
Java 数组、排序和查找(3)
数组、排序和查找复习
50 0
Java 数组、排序和查找(3)
|
数据可视化 搜索推荐 Java
二分查找(java 超详图解 递归 以及其他查找排序算法)
1.堆排序 2.快速排序 3.归并排序 4.冒泡排序 5.选择排序 6.顺序查找 7.二分查找 查找图解: 代码详解: 代码
二分查找(java 超详图解 递归 以及其他查找排序算法)
|
存储 算法 Java
Java数据结构与算法——二叉树前中后序遍历 & 查找 & 删除
Java数据结构与算法——二叉树前中后序遍历 & 查找 & 删除
Java数据结构与算法——二叉树前中后序遍历 & 查找 & 删除