String.Substring Method (Int32, Int32)

Microsoft Silverlight will reach end of support after October 2021. Learn more.

Retrieves a substring from this instance. The substring starts at a specified character position and has a specified length.

Namespace:  System
Assembly:  mscorlib (in mscorlib.dll)

Syntax

'Declaration
<SecuritySafeCriticalAttribute> _
Public Function Substring ( _
    startIndex As Integer, _
    length As Integer _
) As String
[SecuritySafeCriticalAttribute]
public string Substring(
    int startIndex,
    int length
)

Parameters

  • startIndex
    Type: System.Int32
    The zero-based starting character position of a substring in this instance.
  • length
    Type: System.Int32
    The number of characters in the substring.

Return Value

Type: System.String
A string that is equivalent to the substring of length length that begins at startIndex in this instance, or Empty if startIndex is equal to the length of this instance and length is zero.

Exceptions

Exception Condition
ArgumentOutOfRangeException

startIndex plus length indicates a position not within this instance.

-or-

startIndex or length is less than zero.

Remarks

startIndex is zero-based.

NoteNote:

This method does not modify the value of the current instance. Instead, it returns a new string with length characters starting from the startIndex character position in the current instance.

Examples

The following code example uses the Substring method in three cases to isolate substrings within a string. In two cases the substrings are used in comparisons, and in the third case an exception is thrown because an invalid parameter is specified.

Dim myString As String = "abc"
Dim test1 As Boolean = myString.Substring(2, 1).Equals("c") ' This is true.
outputBlock.Text &= test1 & vbCrLf
Dim test2 As Boolean = String.IsNullOrEmpty(myString.Substring(3, 0)) ' This is true.
outputBlock.Text &= test2 & vbCrLf
Try
   Dim str3 AS String = myString.Substring(3, 1) ' This throws ArgumentOutOfRangeException.
   outputBlock.Text &= str3 & vbCrLf
Catch e AS ArgumentOutOfRangeException
   outputBlock.Text &= e.Message & vbCrLf
End Try   
String myString = "abc";
bool test1 = myString.Substring(2, 1).Equals("c"); // This is true.
outputBlock.Text += test1 + "\n";
bool test2 = String.IsNullOrEmpty(myString.Substring(3, 0)); // This is true.
outputBlock.Text += test2 + "\n";
try {
   string str3 = myString.Substring(3, 1); // This throws ArgumentOutOfRangeException.
   outputBlock.Text += str3 + "\n";
}
catch (ArgumentOutOfRangeException e) {
   outputBlock.Text += e.Message + "\n";
}            

Version Information

Silverlight

Supported in: 5, 4, 3

Silverlight for Windows Phone

Supported in: Windows Phone OS 7.1, Windows Phone OS 7.0

XNA Framework

Supported in: Xbox 360, Windows Phone OS 7.0

Platforms

For a list of the operating systems and browsers that are supported by Silverlight, see Supported Operating Systems and Browsers.