英語で読む

次の方法で共有


String.IndexOfAny メソッド

定義

Unicode 文字の指定した配列内にある文字がこのインスタンスで最初に見つかった位置のインデックスをレポートします。 このインスタンス内で配列内の文字が見つからない場合、このメソッドは -1 を返します。

オーバーロード

IndexOfAny(Char[])

Unicode 文字の指定した配列内にある文字がこのインスタンスで最初に見つかった位置の 0 から始まるインデックスをレポートします。

IndexOfAny(Char[], Int32)

Unicode 文字の指定した配列内にある文字がこのインスタンスで最初に見つかった位置の 0 から始まるインデックスをレポートします。 検索は、指定した文字位置から開始されます。

IndexOfAny(Char[], Int32, Int32)

Unicode 文字の指定した配列内にある文字がこのインスタンスで最初に見つかった位置の 0 から始まるインデックスをレポートします。 検索は指定した文字位置から開始され、指定した数の文字位置が検査されます。

IndexOfAny(Char[])

ソース:
String.Searching.cs
ソース:
String.Searching.cs
ソース:
String.Searching.cs

Unicode 文字の指定した配列内にある文字がこのインスタンスで最初に見つかった位置の 0 から始まるインデックスをレポートします。

C#
public int IndexOfAny (char[] anyOf);

パラメーター

anyOf
Char[]

シークする 1 つ以上の文字を格納している、Unicode 文字の配列。

戻り値

anyOf 内の文字がこのインスタンスで最初に見つかった場所の 0 から始まるインデックスでの位置。anyOf 内に文字が見つからなかった場合は -1。

例外

anyOfnullです。

次の例では、文字列内の最初の母音を検索します。

C#
using System;

public class Example
{
   public static void Main()
   {
      char[] chars = { 'a', 'e', 'i', 'o', 'u', 'y', 
                       'A', 'E', 'I', 'O', 'U', 'Y' };
      String s = "The long and winding road...";
      Console.WriteLine("The first vowel in \n   {0}\nis found at position {1}", 
                        s, s.IndexOfAny(chars) + 1);                         
   }
}
// The example displays the following output:
//       The first vowel in
//          The long and winding road...
//       is found at position 3

注釈

インデックス番号は 0 から始まります。

anyOf 検索では、大文字と小文字が区別されます。 が空の配列の場合 anyOf 、メソッドは文字列の先頭 (つまりインデックス 0) で一致を検索します。

このメソッドは序数 (カルチャに依存しない) 検索を実行します。この検索では、Unicode スカラー値が同じ場合にのみ、文字が別の文字と等価であると見なされます。 カルチャに依存する検索を実行するには、 メソッドを使用 CompareInfo.IndexOf します。ここで、合字 "Æ" (U+00C6) などの事前計算済み文字を表す Unicode スカラー値は、カルチャに応じて"AE" (U+0041、U+0045) など、正しいシーケンス内の文字のコンポーネントの出現と同じと見なされる場合があります。

こちらもご覧ください

適用対象

.NET 9 およびその他のバージョン
製品 バージョン
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

IndexOfAny(Char[], Int32)

ソース:
String.Searching.cs
ソース:
String.Searching.cs
ソース:
String.Searching.cs

Unicode 文字の指定した配列内にある文字がこのインスタンスで最初に見つかった位置の 0 から始まるインデックスをレポートします。 検索は、指定した文字位置から開始されます。

C#
public int IndexOfAny (char[] anyOf, int startIndex);

パラメーター

anyOf
Char[]

シークする 1 つ以上の文字を格納している、Unicode 文字の配列。

startIndex
Int32

検索が開始される位置。

戻り値

anyOf 内の文字がこのインスタンスで最初に見つかった場所の 0 から始まるインデックスでの位置。anyOf 内に文字が見つからなかった場合は -1。

例外

anyOfnullです。

startIndex が負の値です。

または

startIndex が、このインスタンス中の文字数を超えています。

次の例では、文字列 "is" の任意の文字が別の文字列の部分文字列内で出現するインデックスを検索します。

C#
// Sample for String.IndexOfAny(Char[], Int32)
using System;

class Sample {
    public static void Main()
    {
    string br1 = "0----+----1----+----2----+----3----+----4----+----5----+----6----+-";
    string br2 = "0123456789012345678901234567890123456789012345678901234567890123456";
    string str = "Now is the time for all good men to come to the aid of their party.";
    int start;
    int at;
    string target = "is";
    char[] anyOf = target.ToCharArray();

    start = str.Length/2;
    Console.WriteLine();
    Console.WriteLine("The first character occurrence from position {0} to {1}.",
                           start, str.Length-1);
    Console.WriteLine("{1}{0}{2}{0}{3}{0}", Environment.NewLine, br1, br2, str);
    Console.Write("A character in '{0}' occurs at position: ", target);

    at = str.IndexOfAny(anyOf, start);
    if (at > -1)
        Console.Write(at);
    else
        Console.Write("(not found)");
    Console.WriteLine();
    }
}
/*

The first character occurrence from position 33 to 66.
0----+----1----+----2----+----3----+----4----+----5----+----6----+-
0123456789012345678901234567890123456789012345678901234567890123456
Now is the time for all good men to come to the aid of their party.

A character in 'is' occurs at position: 49

*/

注釈

インデックス番号は 0 から始まります。 パラメーターの範囲は startIndex 、文字列インスタンスの長さより 0 から 1 未満です。

検索の範囲は、文字列の末尾まで startIndex です。

anyOf 検索では、大文字と小文字が区別されます。

このメソッドは序数 (カルチャに依存しない) 検索を実行します。この検索では、Unicode スカラー値が同じ場合にのみ、文字が別の文字と等価であると見なされます。 カルチャに依存する検索を実行するには、 メソッドを使用 CompareInfo.IndexOf します。ここで、合字 "Æ" (U+00C6) などの事前計算済み文字を表す Unicode スカラー値は、カルチャに応じて"AE" (U+0041、U+0045) など、正しいシーケンス内の文字のコンポーネントの出現と同じと見なされる場合があります。

こちらもご覧ください

適用対象

.NET 9 およびその他のバージョン
製品 バージョン
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

IndexOfAny(Char[], Int32, Int32)

ソース:
String.Searching.cs
ソース:
String.Searching.cs
ソース:
String.Searching.cs

Unicode 文字の指定した配列内にある文字がこのインスタンスで最初に見つかった位置の 0 から始まるインデックスをレポートします。 検索は指定した文字位置から開始され、指定した数の文字位置が検査されます。

C#
public int IndexOfAny (char[] anyOf, int startIndex, int count);

パラメーター

anyOf
Char[]

シークする 1 つ以上の文字を格納している、Unicode 文字の配列。

startIndex
Int32

検索が開始される位置。

count
Int32

検査する文字位置の数。

戻り値

anyOf 内の文字がこのインスタンスで最初に見つかった場所の 0 から始まるインデックスでの位置。anyOf 内に文字が見つからなかった場合は -1。

例外

anyOfnullです。

count または startIndex が負の値です。

または

count + startIndex が、このインスタンス中の文字数を超えています。

次の例では、別の文字列の部分文字列内で文字列 "aid" の任意の文字が出現するインデックスを検索します。

C#
// Sample for String.IndexOfAny(Char[], Int32, Int32)
using System;

class Sample {
    public static void Main()
    {
    string br1 = "0----+----1----+----2----+----3----+----4----+----5----+----6----+-";
    string br2 = "0123456789012345678901234567890123456789012345678901234567890123456";
    string str = "Now is the time for all good men to come to the aid of their party.";
    int start;
    int at;
    int count;
    string target = "aid";
    char[] anyOf = target.ToCharArray();

    start = (str.Length-1)/3;
    count = (str.Length-1)/4;
    Console.WriteLine();
    Console.WriteLine("The first character occurrence from position {0} for {1} characters.", start, count);
    Console.WriteLine("{1}{0}{2}{0}{3}{0}", Environment.NewLine, br1, br2, str);
    Console.Write("A character in '{0}' occurs at position: ", target);

    at = str.IndexOfAny(anyOf, start, count);
    if (at > -1)
        Console.Write(at);
    else
        Console.Write("(not found)");
    Console.WriteLine();
    }
}
/*

The first character occurrence from position 22 for 16 characters.
0----+----1----+----2----+----3----+----4----+----5----+----6----+-
0123456789012345678901234567890123456789012345678901234567890123456
Now is the time for all good men to come to the aid of their party.

A character in 'aid' occurs at position: 27

*/

注釈

検索は から startIndex 始まり、-1 に startIndex + count 進みます。 の startIndex + count 文字は検索に含まれません。

インデックス番号は 0 から始まります。 パラメーターの範囲は startIndex 、文字列インスタンスの長さより 0 から 1 未満です。

anyOf 検索では、大文字と小文字が区別されます。

このメソッドは序数 (カルチャに依存しない) 検索を実行します。この検索では、Unicode スカラー値が同じ場合にのみ、文字が別の文字と等価であると見なされます。 カルチャに依存する検索を実行するには、 メソッドを使用 CompareInfo.IndexOf します。ここで、合字 "Æ" (U+00C6) などの事前計算済み文字を表す Unicode スカラー値は、カルチャに応じて"AE" (U+0041、U+0045) など、正しいシーケンス内の文字のコンポーネントの出現と同じと見なされる場合があります。

こちらもご覧ください

適用対象

.NET 9 およびその他のバージョン
製品 バージョン
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0