英語で読む

次の方法で共有


String.StartsWith メソッド

定義

オーバーロード

StartsWith(String, Boolean, CultureInfo)

指定したカルチャを使用して比較したときに、この文字列インスタンスの先頭が指定した文字列と一致するかどうかを判断します。

StartsWith(String, StringComparison)

指定した比較オプションを使用して比較するときに、この文字列インスタンスの先頭が指定した文字列と一致するかどうかを判断します。

StartsWith(Char)

この文字列インスタンスが指定した文字で始まるかどうかを判断します。

StartsWith(String)

この文字列インスタンスの先頭が指定した文字列と一致するかどうかを判断します。

StartsWith(String, Boolean, CultureInfo)

ソース:
String.Comparison.cs
ソース:
String.Comparison.cs
ソース:
String.Comparison.cs

指定したカルチャを使用して比較したときに、この文字列インスタンスの先頭が指定した文字列と一致するかどうかを判断します。

public bool StartsWith (string value, bool ignoreCase, System.Globalization.CultureInfo? culture);
public bool StartsWith (string value, bool ignoreCase, System.Globalization.CultureInfo culture);

パラメーター

value
String

比較する文字列。

ignoreCase
Boolean

比較中に大文字と小文字を区別しない true。それ以外の場合は、falseします。

culture
CultureInfo

この文字列と value の比較方法を決定するカルチャ情報。 culturenullされている場合は、現在のカルチャが使用されます。

戻り値

value パラメーターがこの文字列の先頭と一致するかどうかを true します。それ以外の場合は、falseします。

例外

valuenullです。

次の例では、文字列が別の文字列の先頭に出現するかどうかを決定します。 StartsWith メソッドは、大文字と小文字の区別、大文字と小文字の区別、検索の結果に影響を与えるさまざまなカルチャを使用して複数回呼び出されます。

// This code example demonstrates the 
// System.String.StartsWith(String, ..., CultureInfo) method.

using System;
using System.Threading;
using System.Globalization;

class Sample 
{
    public static void Main() 
    {
    string msg1 = "Search for the target string \"{0}\" in the string \"{1}\".\n";
    string msg2 = "Using the {0} - \"{1}\" culture:";
    string msg3 = "  The string to search ends with the target string: {0}";
    bool result = false;
    CultureInfo ci;

// Define a target string to search for.
// U+00c5 = LATIN CAPITAL LETTER A WITH RING ABOVE
    string capitalARing = "\u00c5";

// Define a string to search. 
// The result of combining the characters LATIN SMALL LETTER A and COMBINING 
// RING ABOVE (U+0061, U+030a) is linguistically equivalent to the character 
// LATIN SMALL LETTER A WITH RING ABOVE (U+00e5).
    string aRingXYZ = "\u0061\u030a" + "xyz";

// Clear the screen and display an introduction.
    Console.Clear();

// Display the string to search for and the string to search.
    Console.WriteLine(msg1, capitalARing, aRingXYZ);

// Search using English-United States culture.
    ci = new CultureInfo("en-US");
    Console.WriteLine(msg2, ci.DisplayName, ci.Name);

    Console.WriteLine("Case sensitive:");
    result = aRingXYZ.StartsWith(capitalARing, false, ci);
    Console.WriteLine(msg3, result);

    Console.WriteLine("Case insensitive:");
    result = aRingXYZ.StartsWith(capitalARing, true, ci);
    Console.WriteLine(msg3, result);
    Console.WriteLine();

// Search using Swedish-Sweden culture.
    ci = new CultureInfo("sv-SE");
    Console.WriteLine(msg2, ci.DisplayName, ci.Name);

    Console.WriteLine("Case sensitive:");
    result = aRingXYZ.StartsWith(capitalARing, false, ci);
    Console.WriteLine(msg3, result);

    Console.WriteLine("Case insensitive:");
    result = aRingXYZ.StartsWith(capitalARing, true, ci);
    Console.WriteLine(msg3, result);
    }
}

/*
Note: This code example was executed on a console whose user interface 
culture is "en-US" (English-United States).

Search for the target string "Å" in the string "a°xyz".

Using the English (United States) - "en-US" culture:
Case sensitive:
  The string to search ends with the target string: False
Case insensitive:
  The string to search ends with the target string: True

Using the Swedish (Sweden) - "sv-SE" culture:
Case sensitive:
  The string to search ends with the target string: False
Case insensitive:
  The string to search ends with the target string: False

*/

注釈

このメソッドは、value パラメーターを、valueと同じ長さの文字列の先頭にある部分文字列と比較し、等しいかどうかを示す値を返します。 等しくするには、value 空の文字列 (String.Empty) である必要があります。また、この同じインスタンスへの参照であるか、このインスタンスの先頭と一致している必要があります。

このメソッドは、指定した大文字と小文字の区別とカルチャを使用して比較を実行します。

適用対象

.NET 9 およびその他のバージョン
製品 バージョン
.NET Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 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 2.0, 2.1

StartsWith(String, StringComparison)

ソース:
String.Comparison.cs
ソース:
String.Comparison.cs
ソース:
String.Comparison.cs

指定した比較オプションを使用して比較するときに、この文字列インスタンスの先頭が指定した文字列と一致するかどうかを判断します。

public bool StartsWith (string value, StringComparison comparisonType);
[System.Runtime.InteropServices.ComVisible(false)]
public bool StartsWith (string value, StringComparison comparisonType);

パラメーター

value
String

比較する文字列。

comparisonType
StringComparison

この文字列と value の比較方法を決定する列挙値の 1 つ。

戻り値

このインスタンスが valueで始まるかどうかを true します。それ以外の場合は、falseします。

属性

例外

valuenullです。

comparisonTypeStringComparison 値ではありません。

次の例では、"The" という単語で始まる長い文字列の先頭にある文字列 "the" を検索します。 この例の出力に示すように、カルチャを区別せずに大文字と小文字を区別する比較を実行する StartsWith(String, StringComparison) メソッドの呼び出しは文字列と一致しませんが、カルチャと大文字と小文字を区別しない比較を実行する呼び出しは文字列と一致します。

using System;

public class Example
{
   public static void Main()
   {
      String title = "The House of the Seven Gables";
      String searchString = "the";
      StringComparison comparison = StringComparison.InvariantCulture;
      Console.WriteLine("'{0}':", title);
      Console.WriteLine("   Starts with '{0}' ({1:G} comparison): {2}",
                        searchString, comparison,
                        title.StartsWith(searchString, comparison));

      comparison = StringComparison.InvariantCultureIgnoreCase;
      Console.WriteLine("   Starts with '{0}' ({1:G} comparison): {2}",
                        searchString, comparison,
                        title.StartsWith(searchString, comparison));
   }
}
// The example displays the following output:
//       'The House of the Seven Gables':
//          Starts with 'the' (InvariantCulture comparison): False
//          Starts with 'the' (InvariantCultureIgnoreCase comparison): True

次の例では、文字列が特定の部分文字列で始まるかどうかを判断します。 2 次元文字列配列を初期化します。 2 番目のディメンションの最初の要素には文字列が含まれており、2 番目の要素には最初の文字列の先頭で検索する文字列が含まれています。 結果は、カルチャの選択、大文字と小文字の区別が無視されるかどうか、および序数比較が実行されるかどうかによって影響を受けます。 文字列インスタンスに合字が含まれている場合、カルチャに依存する比較とその連続する文字が正常に一致することに注意してください。

using System;

public class Example
{
   public static void Main()
   {
      string[,] strings = { {"ABCdef", "abc" },                    
                            {"ABCdef", "abc" },  
                            {"œil","oe" },
                            { "læring}", "lae" } };
      for (int ctr1 = strings.GetLowerBound(0); ctr1 <= strings.GetUpperBound(0); ctr1++)
      {
            foreach (string cmpName in Enum.GetNames(typeof(StringComparison)))
            { 
               StringComparison strCmp = (StringComparison) Enum.Parse(typeof(StringComparison), 
                                                      cmpName);
               string instance = strings[ctr1, 0];
               string value = strings[ctr1, 1];
               Console.WriteLine("{0} starts with {1}: {2} ({3} comparison)", 
                                 instance, value, 
                                 instance.StartsWith(value, strCmp), 
                                 strCmp); 
            }
            Console.WriteLine();   
      }   
   }
}
// The example displays the following output:
//       ABCdef starts with abc: False (CurrentCulture comparison)
//       ABCdef starts with abc: True (CurrentCultureIgnoreCase comparison)
//       ABCdef starts with abc: False (InvariantCulture comparison)
//       ABCdef starts with abc: True (InvariantCultureIgnoreCase comparison)
//       ABCdef starts with abc: False (Ordinal comparison)
//       ABCdef starts with abc: True (OrdinalIgnoreCase comparison)
//       
//       ABCdef starts with abc: False (CurrentCulture comparison)
//       ABCdef starts with abc: True (CurrentCultureIgnoreCase comparison)
//       ABCdef starts with abc: False (InvariantCulture comparison)
//       ABCdef starts with abc: True (InvariantCultureIgnoreCase comparison)
//       ABCdef starts with abc: False (Ordinal comparison)
//       ABCdef starts with abc: True (OrdinalIgnoreCase comparison)
//       
//       œil starts with oe: True (CurrentCulture comparison)
//       œil starts with oe: True (CurrentCultureIgnoreCase comparison)
//       œil starts with oe: True (InvariantCulture comparison)
//       œil starts with oe: True (InvariantCultureIgnoreCase comparison)
//       œil starts with oe: False (Ordinal comparison)
//       œil starts with oe: False (OrdinalIgnoreCase comparison)
//       
//       læring} starts with lae: True (CurrentCulture comparison)
//       læring} starts with lae: True (CurrentCultureIgnoreCase comparison)
//       læring} starts with lae: True (InvariantCulture comparison)
//       læring} starts with lae: True (InvariantCultureIgnoreCase comparison)
//       læring} starts with lae: False (Ordinal comparison)
//       læring} starts with lae: False (OrdinalIgnoreCase comparison)

注釈

StartsWith メソッドは、value パラメーターをこの文字列の先頭にある部分文字列と比較し、それらが等しいかどうかを示す値を返します。 等しくするには、value がこの同じ文字列への参照であるか、空の文字列 ("") であるか、この文字列の先頭と一致している必要があります。 StartsWith メソッドによって実行される比較の種類は、comparisonType パラメーターの値によって異なります。 比較では、現在のカルチャ (StringComparison.CurrentCultureStringComparison.CurrentCultureIgnoreCase) またはインバリアント カルチャ (StringComparison.InvariantCultureStringComparison.InvariantCultureIgnoreCase) の規則を使用することも、コード ポイント (StringComparison.Ordinal または StringComparison.OrdinalIgnoreCase) の文字ごとの比較で構成することもできます。 比較では、大文字と小文字を区別する (StringComparison.CurrentCultureStringComparison.InvariantCulture、または StringComparison.Ordinal) ことも、大文字と小文字 (StringComparison.CurrentCultureIgnoreCaseStringComparison.InvariantCultureIgnoreCaseStringComparison.OrdinalIgnoreCase) を無視することもできます。

こちらもご覧ください

適用対象

.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 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

StartsWith(Char)

ソース:
String.Comparison.cs
ソース:
String.Comparison.cs
ソース:
String.Comparison.cs

この文字列インスタンスが指定した文字で始まるかどうかを判断します。

public bool StartsWith (char value);

パラメーター

value
Char

比較する文字。

戻り値

value がこの文字列の先頭と一致する場合に true します。それ以外の場合は、falseします。

注釈

このメソッドは、序数 (大文字と小文字を区別し、カルチャを区別しない) 比較を実行します。

適用対象

.NET 9 およびその他のバージョン
製品 バージョン
.NET Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Standard 2.1

StartsWith(String)

ソース:
String.Comparison.cs
ソース:
String.Comparison.cs
ソース:
String.Comparison.cs

この文字列インスタンスの先頭が指定した文字列と一致するかどうかを判断します。

public bool StartsWith (string value);

パラメーター

value
String

比較する文字列。

戻り値

value がこの文字列の先頭と一致する場合に true します。それ以外の場合は、falseします。

例外

valuenullです。

次の例では、StartsWith(String) メソッドを使用して文字列の先頭から HTML 開始タグを削除する StripStartTags メソッドを定義します。 StripStartTags メソッドは、行の先頭にある複数の HTML 開始タグが確実に削除されるように再帰的に呼び出されることに注意してください。 この例では、文字列に埋め込まれた HTML タグは削除されません。

using System;

public class Example
{
   public static void Main() {
      string [] strSource = { "<b>This is bold text</b>", "<H1>This is large Text</H1>",
                "<b><i><font color=green>This has multiple tags</font></i></b>",
                "<b>This has <i>embedded</i> tags.</b>",
                "<This line simply begins with a lesser than symbol, it should not be modified" };

      // Display the initial string array.
      Console.WriteLine("The original strings:");
      Console.WriteLine("---------------------");
      foreach (var s in strSource)
         Console.WriteLine(s);
      Console.WriteLine();

      Console.WriteLine("Strings after starting tags have been stripped:");
      Console.WriteLine("-----------------------------------------------");

      // Display the strings with starting tags removed.
     foreach (var s in strSource)
        Console.WriteLine(StripStartTags(s));
   }

   private static string StripStartTags(string item)
   {
      // Determine whether a tag begins the string.
      if (item.Trim().StartsWith("<")) {
         // Find the closing tag.
         int lastLocation = item.IndexOf( ">" );
         // Remove the tag.
         if (lastLocation >= 0) {
            item =  item.Substring( lastLocation + 1 );

            // Remove any additional starting tags.
            item = StripStartTags(item);
         }
      }

      return item;
   }
}
// The example displays the following output:
//    The original strings:
//    ---------------------
//    <b>This is bold text</b>
//    <H1>This is large Text</H1>
//    <b><i><font color = green>This has multiple tags</font></i></b>
//    <b>This has <i>embedded</i> tags.</b>
//    <This line simply begins with a lesser than symbol, it should not be modified
//
//    Strings after starting tags have been stripped:
//    -----------------------------------------------
//    This is bold text</b>
//    This is large Text</H1>
//    This has multiple tags</font></i></b>
//    This has <i>embedded</i> tags.</b>
//    <This line simply begins with a lesser than symbol, it should not be modified

注釈

このメソッドは、value を、valueと同じ長さのこのインスタンスの先頭にある部分文字列と比較し、等しいかどうかを示す値を返します。 等しくするには、value 空の文字列 (String.Empty) である必要があります。また、この同じインスタンスへの参照であるか、このインスタンスの先頭と一致している必要があります。

このメソッドは、現在のカルチャを使用して単語 (大文字と小文字が区別され、カルチャに依存) の比較を実行します。

注意 (呼び出し元)

文字列を使用するためのベスト プラクティス で説明したように、既定値に置き換える文字列比較メソッドを呼び出すのではなく、パラメーターを明示的に指定する必要があるメソッドを呼び出さないようにすることをお勧めします。 現在のカルチャの文字列比較規則を使用して、文字列が特定の部分文字列で始まるかどうかを判断するには、comparisonType パラメーターの値を使用して StartsWith(String, StringComparison) メソッドのオーバーロードを CurrentCulture 呼び出すことによって、意図を明示的に通知します。 言語に対応した比較が必要ない場合は、Ordinalの使用を検討してください。

こちらもご覧ください

適用対象

.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