Прочитать на английском

Поделиться через


String.LastIndexOfAny Метод

Определение

Возвращает позицию индекса с отсчетом от нуля последнего вхождения в данном экземпляре какого-либо одного или нескольких символов, указанных в массиве символов Юникода. Метод возвращает -1, если знаки массива не найдены в этом экземпляре.

Перегрузки

LastIndexOfAny(Char[])

Возвращает позицию индекса с отсчетом от нуля последнего вхождения в данном экземпляре какого-либо одного или нескольких символов, указанных в массиве символов Юникода.

LastIndexOfAny(Char[], Int32)

Возвращает позицию индекса с отсчетом от нуля последнего вхождения в данном экземпляре какого-либо одного или нескольких символов, указанных в массиве символов Юникода. Поиск начинается с указанной позиции символа и выполняется в обратном направлении до начала строки.

LastIndexOfAny(Char[], Int32, Int32)

Возвращает позицию индекса с отсчетом от нуля последнего вхождения в данном экземпляре какого-либо одного или нескольких символов, указанных в массиве символов Юникода. Поиск начинается с указанной позиции символа и выполняется в обратном направлении до начала строки для заданного числа позиций символов.

LastIndexOfAny(Char[])

Исходный код:
String.Searching.cs
Исходный код:
String.Searching.cs
Исходный код:
String.Searching.cs

Возвращает позицию индекса с отсчетом от нуля последнего вхождения в данном экземпляре какого-либо одного или нескольких символов, указанных в массиве символов Юникода.

public int LastIndexOfAny (char[] anyOf);

Параметры

anyOf
Char[]

Массив знаков Юникода, содержащий один или несколько искомых знаков.

Возвращаемое значение

Значение индекса последнего вхождения какого-либо знака из anyOf в данном экземпляре; -1, если ни один знак из anyOf не был найден.

Исключения

anyOf имеет значение null.

Примеры

В следующем примере выполняется поиск индекса последнего вхождения любого символа в строке is в другой строке.

// Sample for String.LastIndexOfAny(Char[])
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-1;
    Console.WriteLine("The last character occurrence  from position {0} to 0.", start);
    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.LastIndexOfAny(anyOf);
    if (at > -1)
        Console.Write(at);
    else
        Console.Write("(not found)");
    Console.Write("{0}{0}{0}", Environment.NewLine);
    }
}
/*
This example produces the following results:
The last character occurrence  from position 66 to 0.
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: 58


*/

Комментарии

Нумерация индекса начинается с нуля.

Этот метод начинает поиск с последней позиции символа данного экземпляра и переходит к началу до тех пор, пока не будет найден символ в anyOf или не будет проверена первая позиция символа. При поиске учитывается регистр.

Этот метод выполняет порядковый поиск (без учета языка и региональных параметров), при котором символ считается эквивалентным другому символу только в том случае, если скалярные значения Юникода совпадают. Чтобы выполнить поиск с учетом языка и региональных параметров, используйте CompareInfo.LastIndexOf метод , в котором скалярное значение Юникода, представляющее предварительно скомпилированные символы, например лигатуру "Æ" (U+00C6), может считаться эквивалентным любому вхождениям компонентов символа в правильной последовательности, например "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

LastIndexOfAny(Char[], Int32)

Исходный код:
String.Searching.cs
Исходный код:
String.Searching.cs
Исходный код:
String.Searching.cs

Возвращает позицию индекса с отсчетом от нуля последнего вхождения в данном экземпляре какого-либо одного или нескольких символов, указанных в массиве символов Юникода. Поиск начинается с указанной позиции символа и выполняется в обратном направлении до начала строки.

public int LastIndexOfAny (char[] anyOf, int startIndex);

Параметры

anyOf
Char[]

Массив знаков Юникода, содержащий один или несколько искомых знаков.

startIndex
Int32

Позиция, с которой начинается поиск. Поиск выполняется от индекса, заданного параметром startIndex, до начала данного экземпляра.

Возвращаемое значение

Значение индекса последнего вхождения какого-либо знака из anyOf в данном экземпляре; -1, если ни один знак из anyOf не был найден или текущий экземпляр равен Empty.

Исключения

anyOf имеет значение null.

Текущий экземпляр не равен Empty, а startIndex указывает позицию вне пределов данного экземпляра.

Примеры

В следующем примере выполняется поиск индекса последнего вхождения любого символа в строке "is" в подстроке другой строки.

// Sample for String.LastIndexOfAny(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-1)/2;
    Console.WriteLine("The last character occurrence  from position {0} to 0.", start);
    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.LastIndexOfAny(anyOf, start);
    if (at > -1)
        Console.Write(at);
    else
        Console.Write("(not found)");
    Console.Write("{0}{0}{0}", Environment.NewLine);
    }
}
/*
This example produces the following results:
The last character occurrence  from position 33 to 0.
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: 12


*/

Комментарии

Нумерация индекса начинается с нуля.

Этот метод начинает поиск в startIndex позиции символа данного экземпляра и переходит к началу до тех пор, пока не будет найден символ в anyOf или пока не будет проверена первая позиция символа. При поиске учитывается регистр.

Этот метод выполняет порядковый поиск (без учета языка и региональных параметров), при котором символ считается эквивалентным другому символу только в том случае, если скалярные значения Юникода совпадают. Чтобы выполнить поиск с учетом языка и региональных параметров, используйте CompareInfo.LastIndexOf метод , в котором скалярное значение Юникода, представляющее предварительно скомпилированные символы, например лигатуру "Æ" (U+00C6), может считаться эквивалентным любому вхождениям компонентов символа в правильной последовательности, например "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

LastIndexOfAny(Char[], Int32, Int32)

Исходный код:
String.Searching.cs
Исходный код:
String.Searching.cs
Исходный код:
String.Searching.cs

Возвращает позицию индекса с отсчетом от нуля последнего вхождения в данном экземпляре какого-либо одного или нескольких символов, указанных в массиве символов Юникода. Поиск начинается с указанной позиции символа и выполняется в обратном направлении до начала строки для заданного числа позиций символов.

public int LastIndexOfAny (char[] anyOf, int startIndex, int count);

Параметры

anyOf
Char[]

Массив знаков Юникода, содержащий один или несколько искомых знаков.

startIndex
Int32

Позиция, с которой начинается поиск. Поиск выполняется от индекса, заданного параметром startIndex, до начала данного экземпляра.

count
Int32

Количество позиций знаков для проверки.

Возвращаемое значение

Значение индекса последнего вхождения какого-либо знака из anyOf в данном экземпляре; -1, если ни один знак из anyOf не был найден или текущий экземпляр равен Empty.

Исключения

anyOf имеет значение null.

Текущий экземпляр не равен Empty, а count или startIndex является отрицательным числом.

-или-

Текущий экземпляр не равен Empty, а разность startIndex и count + 1 меньше нуля.

Примеры

В следующем примере выполняется поиск индекса последнего вхождения любого символа в строке "aid" в подстроке другой строки.

// Sample for String.LastIndexOfAny(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)*2)/3;
    count = (str.Length-1)/3;
    Console.WriteLine("The last 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.LastIndexOfAny(anyOf, start, count);
    if (at > -1)
        Console.Write(at);
    else
        Console.Write("(not found)");
    Console.Write("{0}{0}{0}", Environment.NewLine);
    }
}
/*
This example produces the following results:
The last character occurrence from position 44 for 22 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 позиции символа данного экземпляра и переходит к началу до тех пор, пока не будет найден символ в anyOf или count не будут проверены его позиции. При поиске учитывается регистр.

Этот метод выполняет порядковый поиск (без учета языка и региональных параметров), при котором символ считается эквивалентным другому символу только в том случае, если скалярные значения Юникода совпадают. Чтобы выполнить поиск с учетом языка и региональных параметров, используйте CompareInfo.LastIndexOf метод , в котором скалярное значение Юникода, представляющее предварительно скомпилированные символы, например лигатуру "Æ" (U+00C6), может считаться эквивалентным любому вхождениям компонентов символа в правильной последовательности, например "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