List.PositionOfAny

Синтаксис

List.PositionOfAny(
    list as list,
    values as list,
    optional occurrence as nullable number,
    optional equationCriteria as any
) as any

О нас

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

  • list: список для поиска.
  • values: список значений, которые нужно найти в исходном списке.
  • occurrence: (Необязательно) Конкретный случай для отправки отчетности. Это значение может быть Occurrence.First, Occurrence.Last или Occurrence.All. Если не occurrence указано, Occurrence.First используется.
  • equationCriteria: (необязательно) указывает, как определяется равенство при сравнении значений. Этот параметр может быть функцией селектора ключей, функцией сравнения или списком, содержащим как селектор ключей, так и средство сравнения.

Пример 1

Найдите первую позицию в списке {1, 2, 3}, в которой отображается значение 2 или 3.

Использование

List.PositionOfAny({1, 2, 3}, {2, 3})

Выходные данные

1

Пример 2

Найдите позицию в списке всех вхождений дат за 2022 или 2023 год.

Использование

let
    Source = {
        #date(2021, 5, 10),
        #date(2022, 6, 28),
        #date(2023, 7, 15),
        #date(2025, 12, 31),
        #date(2022, 4, 8),
        #date(2024, 3, 20)
    },
    YearList = List.Transform(Source, each Date.Year(_)),
    TargetYear = {2022, 2023},
    FindPositions = List.PositionOfAny(YearList, TargetYear, Occurrence.All)
in
    FindPositions

Выходные данные

{1, 2, 4}

Пример 3

Найдите позицию последнего вхождения слова "собака" или слова "кот" в списке, игнорируя регистр.

Использование

let
    Source = List.PositionOfAny(
        {"dog", "cat", "DOG", "pony", "bat", "rabbit", "dOG"},
        {"dog", "cat"},
        Occurrence.Last,
        Comparer.OrdinalIgnoreCase
    )
in
    Source

Выходные данные

6

Пример 4

Найдите любую позицию в списке, которая находится в пределах двух единиц числа 17 или 28.

Использование

let
    Source = { 10, 15, 20, 25, 30 },
    Position = List.PositionOfAny(
        Source,
        {17, 28},
        Occurrence.All,
        (x, y) => Number.Abs(x - y) <= 2
    )
in
    Position

Выходные данные

{1, 4}

Критерии уравнения