Как заставить формулу массива применить существующую формулу массива к столбцу?

Обновлено: я понятия не имел, что ссылка на мой основной лист ведет к изображению, а не к моему образцу книги, я понял свою ошибку благодаря @horanimal, и ссылка была исправлена.

Я использую формулу массива на моем Основном листе для заполнения ячеек отфильтрованными данными из моего информационного листа на основе дат в столбце A. Эта формула подсчитывает количество совпадений на информационном листе, определяемом данными основного листа в ячейках B2. и B3, которые соответствуют дате в столбце A, которые имеют либо статус ПРОЙДЕН, либо РЕМОНТ, а затем умножают эту сумму на число в листе данных, наконец, вычитая сумму любых применимых чисел в информационном листе для окончательного результата. .

Основной лист:

Информационный лист:

Я написал эту формулу для ячейки B4 и скопировал ее вниз по столбцу: =ARRAYFORMULA(COUNTA(IFERROR(FILTER(Info!$A$5:$5,Info!$A$2:$2=$A4,Info!$A$3:$3=$B$2,Info!$A$4:$4 = "➕",REGEXMATCH(Info!$A$6:$6,"PASS|REPAIRED"),REGEXMATCH(Info!$A$7:$7,"PASS|REPAIRED"))))*Data!$B$4 -SUM(IFERROR(FILTER(Info!$A$8:$8,Info!$A$2:$2=$A4,Info!$A$3:$3=$B$2,Info!$A$4:$4 = "➕",REGEXMATCH(Info!$A$6:$6,"PASS|REPAIRED"),REGEXMATCH(Info!$A$7:$7,"PASS|REPAIRED")))))

Это дает мне правильные данные, но я пытаюсь добиться того, чтобы только одна формула в ячейке B3 обрабатывала весь столбец и давала мне одни и те же данные. Я пытался переписать формулу таким образом для ячейки C3, но я получаю только первый результат в ячейке C4, а ячейки в C5: C остаются пустыми: = {"➕➕";ARRAYFORMULA(COUNTA(IFERROR(FILTER(Info!A$5:$5,Info!A$2:$2=$A4,Info!A$3:$3=$B$2,Info!A$4:$4 = "➕➕",REGEXMATCH(Info!A$6:$6,"PASS|REPAIRED"),REGEXMATCH(Info!A$7:$7,"PASS|REPAIRED"))))*Data!$B$4 -SUM(IFERROR(FILTER(Info!A$8:$8,Info!A$2:$2=$A4,Info!A$3:$3=$B$2,Info!A$4:$4 = "➕➕",REGEXMATCH(Info!A$6:$6,"PASS|REPAIRED"),REGEXMATCH(Info!A$7:$7,"PASS|REPAIRED")))))}

Как мне правильно переписать это, используя только одну формулу?

Пожалуйста, добавьте некоторые дополнительные данные по вашему вопросу, такие как образец файла фиктивного листа для репликации. Пожалуйста, просмотрите Как создать минимальный воспроизводимый пример. Спасибо.

SputnikDrunk2 19.04.2023 00:41

@ J.Kubassek, можете ли вы привести несколько примеров заголовков и значений для таблицы Info?

horanimal 28.04.2023 20:00

Пожалуйста, смотрите мой обновленный пост, я не понял, что ссылка на мой лист с примерами не указывала на правильное место.

J. Kubassek 28.04.2023 20:09

проверьте ответ ниже, я думаю, что мы его получили! Также, как только мы решим эту проблему, мне бы очень хотелось узнать, для чего это нужно и почему вы идете горизонтально с датами в таблице Info, а не вертикально :)

horanimal 28.04.2023 22:18

Это потрясающе, спасибо! И это для отслеживания ежедневных значений производства на станции с несколькими фильтрами продуктов. Что касается того, почему таблица Info горизонтальна - это просто потому, что было наиболее эффективно настроить ввод данных таким образом, и данные на моем фактическом листе просто передаются на этот лист в том же формате, в котором они были введены - но это может также импортировать горизонтально, если это упрощает создание формул, я на самом деле не думал об этом.

J. Kubassek 28.04.2023 23:19
Стоит ли изучать PHP в 2023-2024 годах?
Стоит ли изучать PHP в 2023-2024 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
1
5
83
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Ваша первая формула великолепна, вам просто нужно немного изменить ее, чтобы использовать функцию BYROW, например:

=BYROW(A4:A,LAMBDA(r,IF(r = "","",ARRAYFORMULA(
  COUNTA(
    IFERROR(
      FILTER(
        Info!$A$5:$5,
        Info!$A$2:$2=r,
        Info!$A$3:$3=$B$2,
        Info!$A$4:$4 = "➕",
        REGEXMATCH(Info!$A$6:$6,"PASS|REPAIRED"),
        REGEXMATCH(Info!$A$7:$7,"PASS|REPAIRED")
      )
    )
  )*Data!$B$4-SUM(
    IFERROR(
      FILTER(
        Info!$A$8:$8,
        Info!$A$2:$2=r,
        Info!$A$3:$3=$B$2,
        Info!$A$4:$4 = "➕",
        REGEXMATCH(Info!$A$6:$6,"PASS|REPAIRED"),
        REGEXMATCH(Info!$A$7:$7,"PASS|REPAIRED")
      )
    )
  )
))))

Все, что я сделал, это добавил BYROW(A4:A,LAMBDA(r,IF(r = "","", перед вашей ФОРМУЛОЙ МАССИВА, а затем везде, где у вас была $A4, я изменил ее на r.

По сути, это делает то, что он циклически перебирает каждую строку в указанном вами диапазоне (A4: A), поэтому вместо перетаскивания вручную он просто вытягивает каждую непустую ячейку в A4: A.

Другие вопросы по теме

Похожие вопросы

Как я могу сравнить 2 списка и использовать результат для вставки строк
Как правильно использовать мою уникальную формулу LAMBA вместо скопированной формулы?
Как использовать рисунок в качестве кнопки для редактирования или навигации по электронной таблице, в которой он существует, без использования класса SpreadsheetApp?
Найти первый подстановочный знак/выражение, соответствующее заданному значению
Добавление данных в лист Google с помощью n8n не работает должным образом. Вместо добавления он заменяет первую строку
Есть ли более эффективная формула для применения условного форматирования с использованием функции ROW?
Переформатировать информацию о листе Google с помощью Apps Script
Как пройти аутентификацию в GogoleApis с помощью Node.js в лямбда-функции
Как вставить 5 определенных строк при встрече с определенным значением
Как я могу создать условный путь к другому разделу в форме Google на основе того, что пользователь ввел в свой краткий ответ?