工作中常用String工具类以及正则

String

String类表示字符串。 Java程序中的所有字符串文字(例如"abc" )都实现为此类的实例。

String Api

方法描述
char charAt(int index)返回指定索引处的 char 值
int compareTo(Object o)把这个字符串和另一个对象比较
int compareTo(String anotherString)按字典顺序比较两个字符串
int compareToIgnoreCase(String str)按字典顺序比较两个字符串,不考虑大小写
String concat(String str)将指定字符串连接到此字符串的结尾
boolean contentEquals(StringBuffer sb)当且仅当字符串与指定的StringBuffer有相同顺序的字符时候返回真
static String copyValueOf(char[] data)返回指定数组中表示该字符序列的 String
static String copyValueOf(char[] data, int offset, int count)返回指定数组中表示该字符序列的 String
boolean endsWith(String suffix)测试此字符串是否以指定的后缀结束
boolean equals(Object anObject)将此字符串与指定的对象比较
boolean equalsIgnoreCase(String anotherString)将此 String 与另一个 String 比较,不考虑大小写
byte[] getBytes()使用指定的字符集将此 String 编码为 byte 序列,并将结果存储到一个新的 byte 数组中
void getChars(int srcBegin, int srcEnd, char[] dst, int dstBegin)将字符从此字符串复制到目标字符数组
int hashCode()返回此字符串的哈希码
int indexOf(int ch)返回指定字符在此字符串中第一次出现处的索引
int indexOf(int ch, int fromIndex)返回在此字符串中第一次出现指定字符处的索引,从指定的索引开始搜索
int indexOf(String str)返回指定子字符串在此字符串中第一次出现处的索引
int indexOf(String str, int fromIndex)返回指定子字符串在此字符串中第一次出现处的索引,从指定的索引开始
int lastIndexOf(int ch)返回指定字符在此字符串中最后一次出现处的索引
int lastIndexOf(int ch, int fromIndex)返回指定字符在此字符串中最后一次出现处的索引,从指定的索引处开始进行反向搜索
int lastIndexOf(String str)返回指定子字符串在此字符串中最右边出现处的索引
int lastIndexOf(String str, int fromIndex)返回指定子字符串在此字符串中最后一次出现处的索引,从指定的索引开始反向搜索
boolean matches(String regex)告知此字符串是否匹配给定的正则表达式
boolean regionMatches(boolean ignoreCase, int toffset, String other, int ooffset, int len)测试两个字符串区域是否相等
boolean regionMatches(int toffset, String other, int ooffset, int len)测试两个字符串区域是否相等
String replace(char oldChar, char newChar)返回一个新的字符串,它是通过用 newChar 替换此字符串中出现的所有 oldChar 得到的
String replaceAll(String regex, String replacement)使用给定的 replacement 替换此字符串所有匹配给定的正则表达式的子字符串
String replaceFirst(String regex, String replacement)使用给定的 replacement 替换此字符串匹配给定的正则表达式的第一个子字符串
String[] split(String regex)根据给定正则表达式的匹配拆分此字符串
String[] split(String regex, int limit)根据匹配给定的正则表达式来拆分此字符串
boolean startsWith(String prefix)测试此字符串是否以指定的前缀开始
boolean startsWith(String prefix, int toffset)测试此字符串从指定索引开始的子字符串是否以指定前缀开始
CharSequence subSequence(int beginIndex, int endIndex)返回一个新的字符序列,它是此序列的一个子序列
String substring(int beginIndex)返回一个新的字符串,它是此字符串的一个子字符串
String substring(int beginIndex, int endIndex)返回一个新字符串,它是此字符串的一个子字符串
char[] toCharArray()将此字符串转换为一个新的字符数组
String toLowerCase()使用默认语言环境的规则将此 String 中的所有字符都转换为小写
String toUpperCase()使用默认语言环境的规则将此 String 中的所有字符都转换为大写
String trim()返回字符串的副本,忽略前导空白和尾部空白
contains(CharSequence chars)判断是否包含指定的字符系列
isEmpty()判断字符串是否为空

StringTokenizer

Java StringTokenizer 属于 java.util 包,用于分隔字符串。

构造方法:

  • StringTokenizer(String str) :构造一个用来解析 str 的 StringTokenizer 对象。java 默认的分隔符是空格("")、制表符(\t)、换行符(\n)、回车符(\r)。
  • StringTokenizer(String str, String delim) :构造一个用来解析 str 的 StringTokenizer 对象,并提供一个指定的分隔符。
  • StringTokenizer(String str, String delim, boolean returnDelims) :构造一个用来解析 str 的 StringTokenizer 对象,并提供一个指定的分隔符,同时,指定是否返回分隔符。

常用方法:

  • int countTokens():返回nextToken方法被调用的次数。
  • boolean hasMoreTokens():返回是否还有分隔符。
  • boolean hasMoreElements():判断枚举 (Enumeration) 对象中是否还有数据。
  • String nextToken():返回从当前位置到下一个分隔符的字符串。
  • Object nextElement():返回枚举 (Enumeration) 对象的下一个元素。
  • String nextToken(String delim):与 4 类似,以指定的分隔符返回结果。
String str = "runoob,google,taobao,facebook,zhihu";
// 以 , 号为分隔符来分隔字符串
StringTokenizer st=new StringTokenizer(str,",");
while(st.hasMoreTokens()) {
    System.out.println(st.nextToken());
}
//运行结果:
runoob
google
taobao
facebook
zhihu

正则匹配

在这里插入图片描述

  • \d表示[0-9]

  • \D表示[^0-9]

  • \w表示[0—9A—Z_a—z]

  • \W表示[^0—9A—Z_a—z]

  • \s表示[\t\n\r\f]

  • \S表示[^\t\n\r\f]

  • \S符号:非空字符

  • \r符号:空格符,与\n、\tab相同

  • \s符号:空字符,只可以匹配一个空格、制表符、回车符、换页符,不可以匹配自己输入的多个空格

  • 表达式:[0—9]{ 3 } \— [0-9]{ 2 } \— [0-9]{ 3 } 的匹配格式为:999—99—999
    因为—符号在正则表达式中有特殊的含义,它表示一个范围,所以在前面加转义字符\

  • ^ :匹配输入字符串的开始位置。注意:[^x] 第一个字符不能是x

  • [^x] 第一个字符不能是x 。

  • $:匹配输入字符串的结束位置

常用正则表达式:

一个或多个汉字

^[\u0391-\uFFE5]+$ 

邮政编码

^[1-9]\d{5}$

QQ号码

^[1-9]\d{4,10}$ 

邮箱

^[a-zA-Z_]{1,}[0-9]{0,}@(([a-zA-z0-9]-*){1,}\.){1,3}[a-zA-z\-]{1,}$ 

用户名(字母开头 + 数字/字母/下划线)

^[A-Za-z][A-Za-z1-9_-]+$

手机号码

^1[3|4|5|8][0-9]\d{8}$ 

URL

^((http|https)://)?([\w-]+\.)+[\w-]+(/[\w-./?%&=]*)?$ 

18位身份证号

^(\d{6})(18|19|20)?(\d{2})([01]\d)([0123]\d)(\d{3})(\d|X|x)?$

IP地址

数值范围正则表达
0-9\d
10-99[1-9]\d
100-1991\d{2}
200-2492[0-4]\d
250-25525[0-5]

第1段地址的正则表达式:

(\d|[1-9]\d|1\d{2}|2[0-4]\d|25[0-5])

IP地址的正则表达式:

^([1-9]|[1-9]\d|1\d{2}|2[0-4]\d|25[0-5])(\.(\d|[1-9]\d|1\d{2}|2[0-4]\d|25[0-5])){3}$
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值