StringBuilder.Replace メソッド

定義

このインスタンス内の指定した文字または文字列のすべての出現箇所を、別の指定した文字または文字列に置き換えます。

オーバーロード

Replace(Char, Char)

このインスタンス内の指定した文字のすべての出現箇所を、別の指定した文字に置き換えます。

Replace(ReadOnlySpan<Char>, ReadOnlySpan<Char>)

このビルダーで、1 つの読み取り専用文字スパンのすべてのインスタンスを別のインスタンスに置き換えます。

Replace(String, String)

このインスタンス内の指定された文字列のすべての出現箇所を、別の指定された文字列に置き換えます。

Replace(Char, Char, Int32, Int32)

このインスタンスの部分文字列内で、指定した文字のすべての出現箇所を別の指定された文字に置き換えます。

Replace(ReadOnlySpan<Char>, ReadOnlySpan<Char>, Int32, Int32)

このビルダーの一部で、1 つの読み取り専用文字スパンのすべてのインスタンスを別のインスタンスに置き換えます。

Replace(String, String, Int32, Int32)

このインスタンスの部分文字列内で、指定した文字列のすべての出現箇所を別の指定された文字列に置き換えます。

次の例では、Replace メソッドを示します。

using namespace System;
using namespace System::Text;
void Show( StringBuilder^ sbs )
{
   String^ rule1 = "0----+----1----+----2----+----3----+----4---";
   String^ rule2 = "01234567890123456789012345678901234567890123";
   Console::WriteLine( rule1 );
   Console::WriteLine( rule2 );
   Console::WriteLine( "{0}", sbs );
   Console::WriteLine();
}

int main()
{
   
   //                  0----+----1----+----2----+----3----+----4---
   //                  01234567890123456789012345678901234567890123
   String^ str = "The quick br!wn d#g jumps #ver the lazy cat.";
   StringBuilder^ sb = gcnew StringBuilder( str );
   Console::WriteLine();
   Console::WriteLine( "StringBuilder.Replace method" );
   Console::WriteLine();
   Console::WriteLine( "Original value:" );
   Show( sb );
   sb->Replace( '#', '!', 15, 29 ); // Some '#' -> '!'
   Show( sb );
   sb->Replace( '!', 'o' ); // All '!' -> 'o'
   Show( sb );
   sb->Replace( "cat", "dog" ); // All "cat" -> "dog"
   Show( sb );
   sb->Replace( "dog", "fox", 15, 20 ); // Some "dog" -> "fox"
   Console::WriteLine( "Final value:" );
   Show( sb );
}

/*
This example produces the following results:

StringBuilder.Replace method

Original value:
0----+----1----+----2----+----3----+----4---
01234567890123456789012345678901234567890123
The quick br!wn d#g jumps #ver the lazy cat.

0----+----1----+----2----+----3----+----4---
01234567890123456789012345678901234567890123
The quick br!wn d!g jumps !ver the lazy cat.

0----+----1----+----2----+----3----+----4---
01234567890123456789012345678901234567890123
The quick brown dog jumps over the lazy cat.

0----+----1----+----2----+----3----+----4---
01234567890123456789012345678901234567890123
The quick brown dog jumps over the lazy dog.

Final value:
0----+----1----+----2----+----3----+----4---
01234567890123456789012345678901234567890123
The quick brown fox jumps over the lazy dog.

*/
using System;
using System.Text;

class Sample
{
    public static void Main()
    {
//                0----+----1----+----2----+----3----+----4---
//                01234567890123456789012345678901234567890123
    string str = "The quick br!wn d#g jumps #ver the lazy cat.";
    StringBuilder sb = new StringBuilder(str);

    Console.WriteLine();
    Console.WriteLine("StringBuilder.Replace method");
    Console.WriteLine();

    Console.WriteLine("Original value:");
    Show(sb);

    sb.Replace('#', '!', 15, 29);        // Some '#' -> '!'
    Show(sb);
    sb.Replace('!', 'o');                // All '!' -> 'o'
    Show(sb);
    sb.Replace("cat", "dog");            // All "cat" -> "dog"
    Show(sb);
    sb.Replace("dog", "fox", 15, 20);    // Some "dog" -> "fox"

    Console.WriteLine("Final value:");
    Show(sb);
    }

    public static void Show(StringBuilder sbs)
    {
    string rule1 = "0----+----1----+----2----+----3----+----4---";
    string rule2 = "01234567890123456789012345678901234567890123";

    Console.WriteLine(rule1);
    Console.WriteLine(rule2);
    Console.WriteLine("{0}", sbs.ToString());
    Console.WriteLine();
    }
}
/*
This example produces the following results:

StringBuilder.Replace method

Original value:
0----+----1----+----2----+----3----+----4---
01234567890123456789012345678901234567890123
The quick br!wn d#g jumps #ver the lazy cat.

0----+----1----+----2----+----3----+----4---
01234567890123456789012345678901234567890123
The quick br!wn d!g jumps !ver the lazy cat.

0----+----1----+----2----+----3----+----4---
01234567890123456789012345678901234567890123
The quick brown dog jumps over the lazy cat.

0----+----1----+----2----+----3----+----4---
01234567890123456789012345678901234567890123
The quick brown dog jumps over the lazy dog.

Final value:
0----+----1----+----2----+----3----+----4---
01234567890123456789012345678901234567890123
The quick brown fox jumps over the lazy dog.

*/
open System.Text

let show (sbs: StringBuilder) =
    let rule1 = "0----+----1----+----2----+----3----+----4---"
    let rule2 = "01234567890123456789012345678901234567890123"
    printfn $"{rule1}\n{rule2}\n{sbs}\n"

//         0----+----1----+----2----+----3----+----4---
//         01234567890123456789012345678901234567890123
let str = "The quick br!wn d#g jumps #ver the lazy cat."
let sb = StringBuilder str

printfn "StringBuilder.Replace method\n"

printfn "Original value:"
show sb

sb.Replace('#', '!', 15, 29) |> ignore // Some '#' -> '!'
show sb
sb.Replace('!', 'o') |> ignore // All '!' -> 'o'
show sb
sb.Replace("cat", "dog") |> ignore // All "cat" -> "dog"
show sb
sb.Replace("dog", "fox", 15, 20) |> ignore // Some "dog" -> "fox"

printfn "Final value:"
show sb

// This example produces the following results:
//       StringBuilder.Replace method
//
//       Original value:
//       0----+----1----+----2----+----3----+----4---
//       01234567890123456789012345678901234567890123
//       The quick br!wn d#g jumps #ver the lazy cat.
//
//       0----+----1----+----2----+----3----+----4---
//       01234567890123456789012345678901234567890123
//       The quick br!wn d!g jumps !ver the lazy cat.
//
//       0----+----1----+----2----+----3----+----4---
//       01234567890123456789012345678901234567890123
//       The quick brown dog jumps over the lazy cat.
//
//       0----+----1----+----2----+----3----+----4---
//       01234567890123456789012345678901234567890123
//       The quick brown dog jumps over the lazy dog.
//
//       Final value:
//       0----+----1----+----2----+----3----+----4---
//       01234567890123456789012345678901234567890123
//       The quick brown fox jumps over the lazy dog.
Imports System.Text

Class Sample
   Public Shared Sub Main()
      '                    0----+----1----+----2----+----3----+----4---
      '                    01234567890123456789012345678901234567890123
      Dim str As String = "The quick br!wn d#g jumps #ver the lazy cat."
      Dim sb As New StringBuilder(str)
      
      Console.WriteLine()
      Console.WriteLine("StringBuilder.Replace method")
      Console.WriteLine()
      
      Console.WriteLine("Original value:")
      Show(sb)
      
      sb.Replace("#"c, "!"c, 15, 29)   ' Some '#' -> '!'
      Show(sb)
      sb.Replace("!"c, "o"c)           ' All '!' -> 'o'
      Show(sb)
      sb.Replace("cat", "dog")         ' All "cat" -> "dog"
      Show(sb)
      sb.Replace("dog", "fox", 15, 20) ' Some "dog" -> "fox"
      Console.WriteLine("Final value:")
      Show(sb)
   End Sub
   
   Public Shared Sub Show(sbs As StringBuilder)
      Dim rule1 As String = "0----+----1----+----2----+----3----+----4---"
      Dim rule2 As String = "01234567890123456789012345678901234567890123"
      
      Console.WriteLine(rule1)
      Console.WriteLine(rule2)
      Console.WriteLine("{0}", sbs.ToString())
      Console.WriteLine()
   End Sub
End Class
'
'This example produces the following results:
'
'StringBuilder.Replace method
'
'Original value:
'0----+----1----+----2----+----3----+----4---
'01234567890123456789012345678901234567890123
'The quick br!wn d#g jumps #ver the lazy cat.
'
'0----+----1----+----2----+----3----+----4---
'01234567890123456789012345678901234567890123
'The quick br!wn d!g jumps !ver the lazy cat.
'
'0----+----1----+----2----+----3----+----4---
'01234567890123456789012345678901234567890123
'The quick brown dog jumps over the lazy cat.
'
'0----+----1----+----2----+----3----+----4---
'01234567890123456789012345678901234567890123
'The quick brown dog jumps over the lazy dog.
'
'Final value:
'0----+----1----+----2----+----3----+----4---
'01234567890123456789012345678901234567890123
'The quick brown fox jumps over the lazy dog.
'

Replace(Char, Char)

ソース:
StringBuilder.cs
ソース:
StringBuilder.cs
ソース:
StringBuilder.cs

このインスタンス内の指定した文字のすべての出現箇所を、別の指定した文字に置き換えます。

public:
 System::Text::StringBuilder ^ Replace(char oldChar, char newChar);
public System.Text.StringBuilder Replace (char oldChar, char newChar);
member this.Replace : char * char -> System.Text.StringBuilder
Public Function Replace (oldChar As Char, newChar As Char) As StringBuilder

パラメーター

oldChar
Char

置換する文字。

newChar
Char

oldCharを置き換える文字。

戻り値

oldCharnewCharに置き換えた、このインスタンスへの参照。

注釈

このメソッドは、大文字と小文字を区別する序数比較を実行して、現在のインスタンス内の oldChar の発生を識別します。 現在の StringBuilder インスタンスのサイズは、置換後も変更されません。

適用対象

Replace(ReadOnlySpan<Char>, ReadOnlySpan<Char>)

ソース:
StringBuilder.cs

このビルダーで、1 つの読み取り専用文字スパンのすべてのインスタンスを別のインスタンスに置き換えます。

public:
 System::Text::StringBuilder ^ Replace(ReadOnlySpan<char> oldValue, ReadOnlySpan<char> newValue);
public System.Text.StringBuilder Replace (ReadOnlySpan<char> oldValue, ReadOnlySpan<char> newValue);
member this.Replace : ReadOnlySpan<char> * ReadOnlySpan<char> -> System.Text.StringBuilder
Public Function Replace (oldValue As ReadOnlySpan(Of Char), newValue As ReadOnlySpan(Of Char)) As StringBuilder

パラメーター

oldValue
ReadOnlySpan<Char>

置換する読み取り専用文字スパン。

newValue
ReadOnlySpan<Char>

oldValue を置き換える読み取り専用文字スパン。

戻り値

注釈

newValue が空の場合、oldValue のインスタンスはこのビルダーから削除されます。

適用対象

Replace(String, String)

ソース:
StringBuilder.cs
ソース:
StringBuilder.cs
ソース:
StringBuilder.cs

このインスタンス内の指定された文字列のすべての出現箇所を、別の指定された文字列に置き換えます。

public:
 System::Text::StringBuilder ^ Replace(System::String ^ oldValue, System::String ^ newValue);
public System.Text.StringBuilder Replace (string oldValue, string newValue);
public System.Text.StringBuilder Replace (string oldValue, string? newValue);
member this.Replace : string * string -> System.Text.StringBuilder
Public Function Replace (oldValue As String, newValue As String) As StringBuilder

パラメーター

oldValue
String

置換する文字列。

newValue
String

oldValueまたは nullを置き換える文字列。

戻り値

oldValue のすべてのインスタンスを newValueに置き換えた、このインスタンスへの参照。

例外

oldValuenullです。

oldValue の長さは 0 です。

このインスタンスの値を拡大すると、MaxCapacityを超えます。

注釈

このメソッドは、大文字と小文字を区別する序数比較を実行して、現在のインスタンス内の oldValue の発生を識別します。 newValuenull または String.Emptyの場合、oldValue のすべての出現箇所が削除されます。

こちらもご覧ください

適用対象

Replace(Char, Char, Int32, Int32)

ソース:
StringBuilder.cs
ソース:
StringBuilder.cs
ソース:
StringBuilder.cs

このインスタンスの部分文字列内で、指定した文字のすべての出現箇所を別の指定された文字に置き換えます。

public:
 System::Text::StringBuilder ^ Replace(char oldChar, char newChar, int startIndex, int count);
public System.Text.StringBuilder Replace (char oldChar, char newChar, int startIndex, int count);
member this.Replace : char * char * int * int -> System.Text.StringBuilder
Public Function Replace (oldChar As Char, newChar As Char, startIndex As Integer, count As Integer) As StringBuilder

パラメーター

oldChar
Char

置換する文字。

newChar
Char

oldCharを置き換える文字。

startIndex
Int32

部分文字列が始まるこのインスタンス内の位置。

count
Int32

部分文字列の長さ。

戻り値

startIndex から startIndex + count -1 までの範囲の newChar に置き換えられた oldChar を持つこのインスタンスへの参照。

例外

startIndex + count は、このインスタンスの値の長さを超えています。

-又は-

startIndex または count が 0 未満です。

注釈

このメソッドは、大文字と小文字を区別する序数比較を実行して、現在のインスタンス内の oldChar の発生を識別します。 現在の StringBuilder オブジェクトのサイズは、置換後も変更されません。

適用対象

Replace(ReadOnlySpan<Char>, ReadOnlySpan<Char>, Int32, Int32)

ソース:
StringBuilder.cs

このビルダーの一部で、1 つの読み取り専用文字スパンのすべてのインスタンスを別のインスタンスに置き換えます。

public:
 System::Text::StringBuilder ^ Replace(ReadOnlySpan<char> oldValue, ReadOnlySpan<char> newValue, int startIndex, int count);
public System.Text.StringBuilder Replace (ReadOnlySpan<char> oldValue, ReadOnlySpan<char> newValue, int startIndex, int count);
member this.Replace : ReadOnlySpan<char> * ReadOnlySpan<char> * int * int -> System.Text.StringBuilder
Public Function Replace (oldValue As ReadOnlySpan(Of Char), newValue As ReadOnlySpan(Of Char), startIndex As Integer, count As Integer) As StringBuilder

パラメーター

oldValue
ReadOnlySpan<Char>

置換する読み取り専用文字スパン。

newValue
ReadOnlySpan<Char>

oldValue を置き換える読み取り専用文字スパン。

startIndex
Int32

このビルダーで開始するインデックス。

count
Int32

このビルダーで読み取る文字数。

戻り値

注釈

newValue が空の場合、oldValue のインスタンスはこのビルダーから削除されます。

適用対象

Replace(String, String, Int32, Int32)

ソース:
StringBuilder.cs
ソース:
StringBuilder.cs
ソース:
StringBuilder.cs

このインスタンスの部分文字列内で、指定した文字列のすべての出現箇所を別の指定された文字列に置き換えます。

public:
 System::Text::StringBuilder ^ Replace(System::String ^ oldValue, System::String ^ newValue, int startIndex, int count);
public System.Text.StringBuilder Replace (string oldValue, string newValue, int startIndex, int count);
public System.Text.StringBuilder Replace (string oldValue, string? newValue, int startIndex, int count);
member this.Replace : string * string * int * int -> System.Text.StringBuilder
Public Function Replace (oldValue As String, newValue As String, startIndex As Integer, count As Integer) As StringBuilder

パラメーター

oldValue
String

置換する文字列。

newValue
String

oldValueまたは nullを置き換える文字列。

startIndex
Int32

部分文字列が始まるこのインスタンス内の位置。

count
Int32

部分文字列の長さ。

戻り値

startIndex から startIndex + count - 1 までの範囲の newValue に置き換えられた、oldValue のすべてのインスタンスを含むこのインスタンスへの参照。

例外

oldValuenullです。

oldValue の長さは 0 です。

startIndex または count が 0 未満です。

-又は-

startIndex プラス count は、このインスタンス内にない文字位置を示します。

-又は-

このインスタンスの値を拡大すると、MaxCapacityを超えます。

注釈

このメソッドは、大文字と小文字を区別する序数比較を実行して、指定した部分文字列内の oldValue の出現を識別します。 newValuenull または String.Emptyの場合、oldValue のすべての出現箇所が削除されます。

こちらもご覧ください

適用対象