Java String.split()函数的用法和正则表达式

在java.lang包中有String.split()方法的原型是: 
public String[] split(String regex, int limit) 
split函数是用于使用特定的切割符(regex)来分隔字符串成一个字符串数组,函数返回是一个数组。在其中每个出现regex的位置都要进行分解。 
需要注意是有以下几点: 
(1)regex是可选项。字符串或正则表达式对象,它标识了分隔字符串时使用的是一个还是多个字符。如果忽略该选项,返回包含整个字符串的单一元素数组。 
(2)limit也是可选项。该值用来限制返回数组中的元素个数。 
(3)要注意转义字符:“.”和“|”都是转义字符,必须得加”\”。同理:*和+也是如此的。 
如果用“.”作为分隔的话,必须是如下写法: 
String.split(“\.”),这样才能正确的分隔开,不能用String.split(“.”); 
如果用“|”作为分隔的话,必须是如下写法: 
String.split(“\|”),这样才能正确的分隔开,不能用String.split(“|”); 
(4)如果在一个字符串中有多个分隔符,可以用“|”作为连字符,比如:“acountId=? and act_id =? or extra=?”,把三个都分隔出来,可以用 
String.split(“and|or”); 
(5)split函数结果与regex密切相关,常见的几种情况如下所示:

public class SplitTest {
    public static void main(String[] args) {
        String str1 = "a-b";        
        String str2 = "a-b-";
        String str3 = "-a-b";
        String str4 = "-a-b-";
        String str5 = "a";
        String str6 = "-";
        String str7 = "--";
        String str8 = "";

        split(str1);
        split(str2);
        split(str3);
        split(str4);
        split(str5);
        split(str6);
        split(str7);
        split(str8);
    }
    public static void split(String demo){
        String[] array = demo.split("-");
        int len = array.length;
        System.out.print("\"" + demo + "\" 分割后的长度为:" + len);
        if(len >= 0)
        {
            System.out.print(",分割后的结果为:");
            for(int i=0; i<len; i++)
            {
                System.out.print(" \""+array[i]+"\"");
            }           
        }
        System.out.println();
    }
}

运行结果为: 
“a-b” 分割后的长度为:2,分割后的结果为: “a” “b” 
“a-b-” 分割后的长度为:2,分割后的结果为: “a” “b” 
“-a-b” 分割后的长度为:3,分割后的结果为: “” “a” “b” 
“-a-b-” 分割后的长度为:3,分割后的结果为: “” “a” “b” 
“a” 分割后的长度为:1,分割后的结果为: “a” 
“-” 分割后的长度为:0,分割后的结果为: 
“–” 分割后的长度为:0,分割后的结果为: 
“” 分割后的长度为:1,分割后的结果为: “” 
由此可以得出来: 
当字符串只包含分隔符时,返回数组没有元素; 
当字符串不包含分隔符时,返回数组只包含一个元素(该字符串本身); 
字符串最尾部出现的分隔符可以看成不存在,不影响字符串的分隔; 
字符串最前端出现的分隔符将分隔出一个空字符串以及剩下的部分的正常分隔。

下面是一些正则表达式:

^\d $  //匹配非负整数(正整数 0) 
^[0-9]*[1-9][0-9]*$  //匹配正整数 
^((-\d )|(0 ))$  //匹配非正整数(负整数 0) 
^-[0-9]*[1-9][0-9]*$  //匹配负整数 
^-?\d $    //匹配整数 
^\d (\.\d )?$  //匹配非负浮点数(正浮点数 0) 
^(([0-9] \.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9] )|([0-9]*[1-9][0-9]*))$  //匹配正浮点数 
^((-\d (\.\d )?)|(0 (\.0 )?))$  //匹配非正浮点数(负浮点数 0) 
^(-(([0-9] \.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9] )|([0-9]*[1-9][0-9]*)))$  //匹配负浮点数 
^(-?\d )(\.\d )?$  //匹配浮点数 
^[A-Za-z] $  //匹配由26个英文字母组成的字符串 
^[A-Z] $  //匹配由26个英文字母的大写组成的字符串 
^[a-z] $  //匹配由26个英文字母的小写组成的字符串 
^[A-Za-z0-9] $  //匹配由数字和26个英文字母组成的字符串 
^\w $  //匹配由数字、26个英文字母或者下划线组成的字符串 
^[\w-] (\.[\w-] )*@[\w-] (\.[\w-] ) $    //匹配email地址 
^[a-zA-z] ://匹配(\w (-\w )*)(\.(\w (-\w )*))*(\?\S*)?$ //匹配url 
匹配中文字符的正则表达式: [\u4e00-\u9fa5] 
匹配双字节字符(包括汉字在内):[^\x00-\xff]
应用:计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)
String.prototype.len=function(){return this.replace([^\x00-\xff]/g,"aa").length;} 
匹配空行的正则表达式:\n[\s| ]*\r 
匹配HTML标记的正则表达式:/<(.*)>.*<\/\1>|<(.*) \/>/ 
匹配首尾空格的正则表达式:(^\s*)|(\s*$)


----------
^\S [a-z A-Z]$ 不能为空 不能有空格 只能是英文字母 
\S{6,} 不能为空 六位以上
^\d $ 不能有空格 不能非数字
(.*)(\.jpg|\.bmp)$ 只能是jpg和bmp格式 
^0$ 至少选一项 
^0{2,}$ 至少选两项 
^[\s|\S]{20,}$ 不能为空 二十字以上 
^\ ?[a-z0-9](([- .]|[_] )?[a-z0-9] )*@([a-z0-9] (\.|\-)) [a-z]{2,6}$邮件 
\w ([- .]\w )*@\w ([-.]\w )*\.\w ([-.]\w )*([,;]\s*\w ([- .]\w )*@\w ([-.]\w )*\.\w ([-.]\w )*)*
输入多个地址用逗号或空格分隔邮件 
^(\([0-9] \))?[0-9]{7,8}$电话号码7位或8位或前面有区号例如(022)87341628 
^[a-z A-Z 0-9 _] @[a-z A-Z 0-9 _] (\.[a-z A-Z 0-9 _] ) (\,[a-z A-Z 0-9 _] @[a-z A-Z 0-9 _] (\.[a-z A-Z 0-9 _] ) )*$ * 只能是字母、数字、下划线,必须有@和.同时格式规范邮件 
 ^\w @\w (\.\w ) (\,\w @\w (\.\w ) )*$上面表达式也可以写成这样子,更精练。 
^\w ((-\w )|(\.\w ))*\@\w ((\.|-)\w )*\.\w $

 

  • 4
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值