Referencing a dynamic, named range between workbooks

I inherited this data structure. I have a bunch of products and their supplier information laid out as so:

Supplier  Order Number  Name  Cost
ACME      00123         A     1
ACME      00321         B     2
ACME      20798         C     3
ACME      11010         D     4
ACME      32333         E     5
ACME      20001         F     6
Babar     20001         G     7
Babar     54687         H     8
Babar     69441         I     9
Babar     65777         J     10

I'm going to be referencing this data from other sheets. Obviously, using vlookup on the order number alone will be unreliable without differentiating between suppliers.

Мое первое решение работает локально, но я не могу заставить его работать между книгами. Я установил именованный диапазон на приведенном выше листе, используя INDIRECT, MATCH и COUNTIF, чтобы диапазоны увеличивались по мере добавления новых элементов.

В этом примере у меня Range_ACME определен как:

= ДВССЫЛ ("В"&MATCH(Лист1 $A$2, Лист1 $ А:! $ А,0)&":D", &(MATCH(Лист1 $A$2, Лист1 $ А:! $ А,0)+COUNTIF(! Лист1 $ A: $ A, Лист1 $ A $ 2) -1))

(На самом деле, я использую другую именованную ячейку в качестве значения поиска MATCH, но я упростил ее для целей тестирования.) Так что я могу найти стоимость для элемента 00123 ACME следующим образом:

= ВПР ("00123",Range_ACME,2, ложь)

При попытке использовать эти диапазоны в другой книге я получаю сообщение об ошибке, что диапазон недопустим. Если я использую более простой именованный диапазон без всякой косвенной дикости, то он работает просто отлично. Здесь Range_ACME_Simple просто

= Лист1 $B$2:$D$7

Я понимаю, что для этого необходимо, чтобы рабочие книги были открыты одновременно. Есть ли другой способ определения динамических диапазонов, или я должен просто объединить имена поставщиков с номерами заказов?

1 ответ

Для простого решения этой проблемы и демонстрации того, что необходимо, я воссоздал предоставленные вами листы и создал именованные диапазоны в книге наборов данных ACME.xlsx относительно их заголовков столбцов данных.

  • поставщик =Sheet1!$A:$A
  • порядок =Sheet1!$B:$B
  • название =Sheet1!$C:$C
  • Стоимость =Sheet1!$D:$D

Затем в другой книге я создал точки входа для значений, которые вы хотите найти (Поставщик и номер заказа). Имя элемента, который вы хотите вернуть, находится в следующей точке входа.

В клетке B3 из создаваемой книги, я вошел

=INDEX('C:\ACME.xlsx'!Name,MATCH(B1&B2,'C:\ACME.xlsx'!Supplier&'C:\ACME.xlsx'!Order,0)) и нажал CTRL + SHIFT + ВВОД

Это дает нам желаемый результат. Теперь, если вы измените ячейку B1 для ACME имя элемента автоматически меняется на F, и вам не нужно открывать рабочую книгу, содержащую структуру данных, если в формуле указан полный путь к файлу.

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