System.String.Split 方法 (String[], StringSplitOptions)

方法描述

返回的字符串数组包含此字符串中的子字符串(由指定字符串数组的元素分隔)。 参数指定是否返回空数组元素。

语法定义(C# System.String.Split 方法 (String[], StringSplitOptions) 的用法)

[ComVisibleAttribute(false)]
public string[] Split(
	string[] separator,
	StringSplitOptions options
)

参数/返回值

参数值/返回值 参数类型/返回类型 参数描述/返回描述
separator System-String[] 分隔此字符串中子字符串的字符串数组、不包含分隔符的空数组或 null。
options System-StringSplitOptions 要省略返回的数组中的空数组元素,则为 RemoveEmptyEntries;要包含返回的数组中的空数组元素,则为 None。
返回值 System.String[] 一个数组,其元素包含此字符串中的子字符串,这些子字符串由 separator 中的一个或多个字符串分隔。 有关更多信息,请参见“备注”一节。

提示和注释

返回值详细信息

返回的数组元素中不包含分隔符字符串。

如果此实例不包含 separator 中的任何字符串,则返回的数组由包含此实例的单个元素组成。 如果 separator 参数为 null 或不包含任何字符,则采用空白字符作为分隔符。 空白字符由 Unicode 标准定义,如果将它们传递给 Char.IsWhiteSpace 方法,将返回 true。 但是,如果调用中的 separator 参数对于此方法重载为 null,则编译器重载决策失败。 要明确标识调用的方法,您的代码必须指示 null 类型。 下面的示例显示明确标识此重载的集中方法。

C#

VB

复制

string phrase = "The quick brown fox";

string[] words;

words = phrase.Split(default(string[]), StringSplitOptions.RemoveEmptyEntries);

words = phrase.Split((string[]) null, StringSplitOptions.RemoveEmptyEntries);

words = phrase.Split(null as string[], StringSplitOptions.RemoveEmptyEntries);

如果 options 参数为 RemoveEmptyEntries 且此实例的长度为零,则返回空数组。

separator 的每个元素定义单独的分隔符,包括一个或多个字符。 如果 options 参数为 None,且两个分隔符相邻,或者在此实例的开头或末尾找到分隔符,则相对应的数组元素包含 Empty。

比较详细信息

Split 方法提取此字符串中的子字符串,这些子字符串由 separator 参数中的一个或多个字符串分隔,然后该方法将这些子字符串作为数组的元素返回。

Split 方法使用区分大小写的序号排序规则执行比较,从而查找分隔符。 有关字、字符串和序号排序的更多信息,请参见 System.Globalization.CompareOptions 枚举。

Split 方法忽略 separator 的任何值为 null 或空字符串 ("") 的元素。

为了在 separator 中的字符串具有公共字符的情况下避免出现不明确的结果,Split 操作从实例值的开始进行到结尾,并匹配 separator 中与实例中的分隔符相等的第一个元素。 实例中子字符串的出现顺序优先于 separator 中元素的顺序。

例如,考虑值为“abcdef”的实例。 如果 separator 中的第一个元素为“ef”,且第二个元素为“bcde”,则拆分操作的结果将是“a”和“f”。 这是因为先遇到实例中的子字符串“bcde”,且它匹配 separator 中的元素,然后才遇到子字符串“f”。

不过,如果 separator 的第一个元素为“bcd”,且第二个元素为“bc”,则拆分操作的结果将是“a”和“ef”。 这是因为“bcd”是 separator 中第一个与实例中的分隔符匹配的分隔符。 如果颠倒分隔符的顺序,使得第一个元素为“bc”且第二个元素为“bcd”,则结果将是“a”和“def”。

性能注意事项

Split 方法为返回的数组对象分配内存,同时还为每一个数组元素分配一个 String 对象。 如果您的应用程序要求达到最佳性能,或者如果在您的应用程序中内存分配管理很关键,请考虑使用 IndexOf 或 IndexOfAny 方法,也可以选择使用 Compare 方法,在字符串中定位子字符串。

如果在分隔符字符处分割字符串,请使用 IndexOf 或 IndexOfAny 方法在字符串中定位分隔符字符。 如果在分隔符字符串处分割字符串,请使用 IndexOf 或 IndexOfAny 方法定位分隔符字符串的第一个字符。 然后使用 Compare 方法确定第一个字符后面的字符是否等于分隔符字符串的其余字符。

此外,如果在多个 Split 方法调用中使用相同的字符集拆分字符串,请考虑创建一个数组并在每个方法调用中都引用该数组。 这可以极大地减少每个方法调用的额外系统开销。

对调用者的说明

在 .NET Framework 3.5 和早期版本中,如果为 Split 方法传递了值为 null 或不包含字符的 separator 参数,该方法用来分割字符串的字符集将与 Trim 方法用来修整字符串的字符集略有不同。 在 .NET Framework 4 中,这两种方法使用完全相同的 Unicode 空白字符集。

System.String.Split 方法 (String[], StringSplitOptions)例子

下面的示例演示通过调用字符串的 String.Split(String[], StringSplitOptions) 方法(其 options 参数等于 StringSplitOptions.None 和 StringSplitOptions.RemoveEmptyEntries)所返回的数组中的差异。

string source = "[stop]ONE[stop][stop]TWO[stop][stop][stop]THREE[stop][stop]";
string[] stringSeparators = new string[] {"[stop]"};
string[] result;

// Display the original string and delimiter string.
Console.WriteLine("Splitting the string:\n   \"{0}\".", source);
Console.WriteLine();
Console.WriteLine("Using the delimiter string:\n   \"{0}\"", 
                  stringSeparators[0]);
Console.WriteLine();                           

// Split a string delimited by another string and return all elements.
result = source.Split(stringSeparators, StringSplitOptions.None);
Console.WriteLine("Result including all elements ({0} elements):", 
                  result.Length);
Console.Write("   ");
foreach (string s in result)
{
   Console.Write("'{0}' ", String.IsNullOrEmpty(s) ? "<>" : s);                   
}
Console.WriteLine();
Console.WriteLine();

// Split delimited by another string and return all non-empty elements.
result = source.Split(stringSeparators, 
                      StringSplitOptions.RemoveEmptyEntries);
Console.WriteLine("Result including non-empty elements ({0} elements):", 
                  result.Length);
Console.Write("   ");
foreach (string s in result)
{
   Console.Write("'{0}' ", String.IsNullOrEmpty(s) ? "<>" : s);                   
}
Console.WriteLine();
/*
This example displays the following output to the console:

Splitting the string:
   "[stop]ONE[stop][stop]TWO[stop][stop][stop]THREE[stop][stop]".
Using the delimiter string:
   "[stop]"

Result using StringSplitOptions.None (all elements):
   '<>' 'ONE' '<>' 'TWO' '<>' '<>' 'THREE' '<>' '<>'

Result using StringSplitOptions.RemoveEmptyEntries:
   'ONE' 'TWO' 'THREE'
*/

异常

异常 异常描述
ArgumentException options 不是 StringSplitOptions 值之一。

命名空间

namespace: System

程序集: mscorlib(在 mscorlib.dll 中)

版本信息

.NET Framework 受以下版本支持:4、3.5、3.0、2.0 .NET Framework Client Profile 受以下版本支持:4、3.5 SP1 受以下版本支持:

适用平台

Windows 7, Windows Vista SP1 或更高版本, Windows XP SP3, Windows XP SP2 x64 Edition, Windows Server 2008(不支持服务器核心), Windows Server 2008 R2(支持 SP1 或更高版本的服务器核心), Windows Server 2003 SP2 .NET Framework 并不是对每个平台的所有版本都提供支持。有关支持的版本的列表,请参见.NET Framework 系统要求。