split的应用

来源:互联网 发布:手机淘宝会员名是什么 编辑:程序博客网 时间:2024/05/21 16:53

split

public String[] split(String regex,                      int limit)
根据匹配给定的正则表达式来拆分此字符串。

此方法返回的数组包含此字符串的每个子字符串,这些子字符串由另一个匹配给定的表达式的子字符串终止或由字符串结束来终止。数组中的子字符串按它们在此字符串中的顺序排列。如果表达式不匹配输入的任何部分,则结果数组只具有一个元素,即此字符串。

limit 参数控制模式应用的次数,因此影响结果数组的长度。如果该限制 n 大于 0,则模式将被最多应用 n - 1 次,数组的长度将不会大于 n,而且数组的最后项将包含超出最后匹配的定界符的所有输入。如果 n 为非正,则模式将被应用尽可能多的次数,而且数组可以是任意长度。如果 n 为零,则模式将被应用尽可能多的次数,数组可有任何长度,并且结尾空字符串将被丢弃。

例如,字符串 "boo:and:foo" 使用这些参数可生成下列结果:

RegexLimit结果
:2{ "boo", "and:foo" }
:5{ "boo", "and", "foo" }
:-2{ "boo", "and", "foo" }
o5{ "b", "", ":and:f", "", "" }
o-2{ "b", "", ":and:f", "", "" }
o0{ "b", "", ":and:f" }

这种形式的方法调用 str.split(regex, n) 产生与以下表达式完全相同的结果:

Pattern.compile(regex).split(str, n)

参数:
regex - 定界正则表达式
limit - 结果阈值,如上所述
返回:
字符串数组,根据给定正则表达式的匹配来拆分此字符串,从而生成此数组
抛出:
PatternSyntaxException - 如果正则表达式的语法无效
从以下版本开始:
1.4
另请参见:
Pattern

split

public String[] split(String regex)
根据给定的正则表达式的匹配来拆分此字符串。

该方法的作用就像是使用给定的表达式和限制参数 0 来调用两参数 split 方法。因此,结果数组中不包括结尾空字符串。

例如,字符串 "boo:and:foo" 产生带有下面这些表达式的结果:

Regex结果
:{ "boo", "and", "foo" }
o{ "b", "", ":and:f" }

参数:
regex - 定界正则表达式
返回:
字符串数组,根据给定正则表达式的匹配来拆分此字符串,从而生成此数组。
抛出:
PatternSyntaxException - 如果正则表达式的语法无效
从以下版本开始:
1.4
另请参见:
Pattern
 
  1. /**
  2.  * @(#)ArraryToDouble.java
  3.  *
  4.  *
  5.  * @author 
  6.  * @version 1.00 2008/9/26
  7.  */
  8. public class ArraryToDouble {
  9.     
  10.     
  11.     public ArraryToDouble() {
  12.         
  13.         
  14.     }
  15.     public static void main(String []args)
  16.     {
  17.         String str="1,2;3,4,5;6,7,8,9;";
  18.         double [][]test;
  19.         String sFirst[]=str.split(";");
  20.         String []sSecond;
  21.         
  22.         test =new double[sFirst.length][];
  23.         forint i=0; i<sFirst.length; i++ )
  24.         {
  25.             sSecond= sFirst[i].split(",");
  26.             test[i]=new double[sSecond.length];
  27.             forint j=0; j<sSecond.length; j++)
  28.                 test[i][j]=Double.parseDouble(sSecond[j]);
  29.         }
  30.         
  31.         for(int  i=0; i<sFirst.length; i++)
  32.         {
  33.             forint j=0; j<test[i].length; j++)
  34.                 System.out.println(test[i][j]);
  35.         }
  36.     }
  37.     
  38.     
  39. }