Выбор фото из выпадающего списка

Постановка задачи

Необходимо сделать так, чтобы в одной из ячеек листа был выпадающий список с наименованиями, при выборе из которого, товар отображался бы рядом в виде фотографии:

dropdown-picture.gif

Видео

Шаг 1. Создаем каталог с фото и даем ему имя

Создаем на Листе 1 мы каталог с наименованиями и фотографиями товаров, состоящий из двух столбцов (Модель и Фото):

show_pics1.gif

Теперь надо дать имя нашему каталогу, чтобы ссылаться на него в будущем. В Excel 2003 и старше для этого идем в меню Вставка - Имя - Присвоить (Insert - Name - Define), а в Excel 2007 и новее - жмем на кнопку Диспетчер имен (Name Manager) на вкладке Формулы (Formulas). Создаем диапазон - вводим имя (например Фотоальбом) и в качестве адреса указываем формулу:

=СМЕЩ(Лист1!$A$1;1;0;СЧЁТЗ(Лист1!$A:$A)-1;1)

=OFFSET(Лист1!$A$1;1;0;COUNTA(Лист1!$A:$A)-1;1)

dropdown-pics1.png

Эта формула определяет последнюю занятую ячейку в столбце А и выдает на выходе диапазон с А2 до этой найденной ячейки. Такая относительно сложная конструкция нужна, чтобы впоследствии дописывать новые модели к нашему списку и не думать об исправлении диапазона. Если дописывать точно ничего не придется, то можете вместо ввода этой страшноватой формулы просто указать =A2:A5

Шаг 2. Выпадающий список для выбора модели

Перейдем на Лист 2 и создадим там ячейку с выпадающим списком для выбора пользователем модели телефона (пусть это будет A1). Выделяем ячейку и идем в меню Данные - Проверка (Data - Validation) или в новых версиях Excel - на вкладку Данные - Проверка данных (Data - Data Validation). Далее в поле Тип данных (Allow) выбираем Список (List), а в качестве Источника (Source) указываем наш Фотоальбом (не забудьте перед ним добавить знак равенства):

dropdown-pics2.png

Кроме того этой ячейке удобно дать имя - снова меню Вставка - Имя - Присвоить и далее вводим имя (например Выбор) и ОК.

Шаг 3. Копируем фотографию

Перенесем первую фотографию из фотоальбома к выпадающему списку. Выделите ячейку с первой фотографией (не сам рисунок, а ячейку!) и

в Excel 2003 и старше -  удерживая Shift, откройте меню Правка (Edit). Там должен появиться невидимый ранее пункт Копировать рисунок (Copy as Picture):

show_pics5.gif

В Excel 2007 и новее можно просто развернуть выпадающий список под кнопкой Копировать (Copy) на Главной (Home) вкладке:

show_pics7.gif

В Excel 2010 появится еще одно дополнительное окно с выбором типа создаваемого изображения:

show_pics8.png

В нем нужно выбрать варианты "как на экране" и "растровый".

Копируем, переходим на Лист 2 к выпадающему списку и в любую пустую ячейку недалеко от него вставляем наш мини-скриншот ячейки с фотографией (меню Правка - Вставить или обычное CTRL+V).

Шаг 4. Создаем динамическую ссылку на выбранную фотографию

Теперь необходимо сделать ссылку, которая будет указывать на ячейку с выбранной фотографией. Открываем меню Вставка - Имя - Присвоить (Insert - Name - Define) или Диспетчер имен (Name Manager) на вкладке Формулы (Formulas) и создаем еще один именованный диапазон:

dropdown-pics3.png

Имя нашей ссылки, допустим, будет Фото, а формула

=СМЕЩ(Лист1!$B$2;ПОИСКПОЗ(Выбор;Фотоальбом;0)-1;0;1;1)

=OFFSET(Лист1!$B$2;MATCH(Выбор;Фотоальбом;0)-1;0;1;1)

Технически, функция ПОИСКПОЗ (MATCH) находит ячейку с нужной моделью в каталоге по названию, а функция СМЕЩ (OFFSET) затем выдает ссылку на соседнюю справа от найденного названия ячейку, т.е. ячейку с фотографией товара.

Шаг 5. Привязываем фотографию к ссылке

Осталось выделить скопированную фотографию на Листе 2 и вписать в строку формул

=Фото

и нажать Enter

show_pics6.gif

Все! :)

Ссылки по теме 




Страницы: 1  2  
SEA
03.10.2012 19:09:58
Отличная статья!!!
Было бы здорово добавить статейку изменения значений ячеек в зависимости от выбора значения в списке :) Или, например, присвоение некоторй переменной выбранного значения списке, или связь с автофильтром или создание подобие автофильтра ... :)
В общем - хорошая тема!
Хорошо что такие есть, СПАСИБО!!! .
igor
03.10.2012 19:11:16
можно ли в ячейке -с- получить и цену на телефон.
спасибо.
Стас
03.10.2012 19:12:04
Можно ли сделать в Excel выпадающий список просто из фото? Т.е. я должен нажать на список, а там вывалются фотографии. Я выбираю нужое фото и оно фиксируется в этой ячейке.
19.12.2014 12:00:33
аналогичный вопрос, можно ли сделать так, как спросил Стас?
22.03.2019 12:24:24
Вопрос актуальный. Есть решение?
Михаил
03.10.2012 19:13:11
Давно искал как это делать. Супер!!!
Максим
03.10.2012 19:13:43
Очень хороший пример я его доработал и сделал интрактивный тест.
15.02.2013 17:58:25
могли бы Вы поделиться конкретным примером:?
Константин
03.10.2012 19:14:19
Старенькая, но классная статья. Учимся с удовольствием.
27.12.2012 12:29:41
Делаю пример, но у меня не получается. Не могу сделать привязку фотографии (=Фото), потому как не вводится формула в строку формул при выделении рисунка.
У меня Excel 2007, но нет выпадающего списка под кнопкой Копировать. Я скопировала рисунок через Вставить - Как рисунок - Копировать как рисунок.
11.02.2013 17:58:48
Да, тоже не смог вставить скопированное изображение так чтобы написать формулу.
Но взял из скачанного примера картинку с уже прописанной формулой - изменил размер и у меня все стало работать. Хотя все-таки интересно как вставить как рисунок - чтобы можно было прописать (вставить) формулу в рисунок?
18.02.2013 12:26:38
Чую, надо видеоурок по этому приему записать - что-то много вопросов осталось. Займусь...
23.01.2013 13:39:37
А как фото вставить-то?:(
15.02.2013 17:16:23
Все конечно супер, но непонятно что и куда скопировать
если те, кто понял, не подставные, набивающие рейтинг, то скажите:
Копируем, переходим на Лист 2 к выпадающему списку и в любую пустую ячейку недалеко от него вставляем (меню Правка - Вставить или обычное CTRL+V).
это что за ячейка:? которая просто содержит данные или это ячейка, в которой потом будут выводиться фото:?
Шаг 5. Привязываем фотографию к ссылке

Осталось выделить скопированную фотографию на Листе 2 и вписать в строку формул

=Фото
не понятно совсем, если 5ть вото, то как быть:? точнее если 5ть моделей телефонов, то как:? 5ть именованных списков:? или что:? или автор просто перемутал наименование листа:? ведь на листе 2 у нас результат, а все данные на листе 1
15.02.2013 17:25:46
да и если выделить фотографвию, как говорит автор, то в строку формул после записи =фото и нажатии ентер, появляется диалоговое окно с сообщением: НЕ ВЕРНАЯ ССЫЛКА
18.02.2013 11:24:12
Для Вас и для всех:
Когда про выборе пункта "Копировать как рисунок" в Excel 2010 появляется диалоговое окно выбора типа рисунка, необходимо выбрать пункт "Растровый".
18.02.2013 17:48:58
Спасибо за уточнение, Иван! Дописал в статью этот момент.
25.02.2013 19:21:49
Еще один вариант: на шаге 4 вместо «хитрой» функции СМЕЩ можно использовать  «нехитрую» функцию ИНДЕКС: Таблицу с названиями моделей и фото преобразуем в «умную» и назовем, к примеру «Таб». Затем в источник данных для проверки внесем формулу: =ДВССЫЛ("Таб[Модель]"). Затем создадим в диспетчере имен ссылку на ячейки с фото (адрес ячейки с выпадающим списком к примеру F1): =ИНДЕКС(Таб;ПОИСКПОЗ(Лист1!$F$1;Таб[Модель];0);2). Ну и потом привязать фото к данной ссылке. Большое спасибо Вам за видеоурок!!!
19.03.2013 23:52:26
А я попробую теперь сделать бейджики своему отделу по аналогии
Ксатати, я так давно искала что-то похожее. Супер, когда невозможное становиться возможным:):):)
11.04.2013 10:47:18
Бейджики оптом по списку лучше делать в Word с помощью слияния.
25.03.2013 18:38:00
Статься интересная, спасибо! :)
В случае если размеры картинок находящиеся в именованном диапазоне "Фото" отличаются*, а возможности привести их к одному размеру по "высоте-ширине"  (чтобы логотип точно влезал в ячейку) нет, то при работе описанного алгоритма часть изображения логотипа режется под размер ячейки :-(
Как быть в этом случае?
Спасибо!

* - есть логотипы  с квадратной пропорцией сторон, а есть с пропорцией прямоугольной.
30.03.2013 20:27:27
Скажите, а почему меняющийся рисунок не выводится на печать?
11.04.2013 10:45:54
Се ля ви. Ничего не поделаешь - печатать его он не будет :(
01.08.2013 02:39:04
У меня печатает изменяемые строки и картинки!
11.02.2015 08:38:04
У меня печатается
03.06.2013 10:37:18
Добрый день, у меня такая же ситуация, как и у Anne: не могу сделать привязку фотографии - курсор отказывается вставать в строку формул, когда выделено изображение (копировала как растровый рисунок). Подскажите, в чем может быть дело?
04.07.2013 23:52:18
Друзья помогите! Посмотрел данный вариант - все круто, вот только одно НО. Мне необходимо что бы рисунок менялся не от значения выбранного в выпадающем списке, а от значения в ячейке, которое меняется автоматически от 1,2,3.... до 27! т.е. если в ячейке значение 1, то рисунок такой-то, если в этой же ячейке значение 2, то рисунок другой....

Заранее спасибо!
24.07.2013 15:37:28
Та же проблема что и у многих с шагом 5.
Курсор просто на становится в строку формул. Я заметил что после вставки фото, оно вставляется не с такими "ручками" как у вас в примере , а с ручками как у обычного рисунка (как после ctrl+c, ctrl+v).
Наверное я не правильно копирую? Но в моем офисе 2007 есть только такой вариант: из выпадающего списка, под кнопкой "Вставить" выбрать "Как рисунок" и затем "Копировать как рисунок"
Правильно ли это?    
06.08.2013 12:36:54
аналогично, не могу вставить =фото... что делаю не так? копирую как растовый рисунок все делаю так же и все равно не вставляется =фото
20.09.2013 13:29:20
Объясните пожалуйста, в примере какой-то особый формат рисунка, в этом наверно и собака зарыта.
Делал все как в примере, только со своими картинками и текстом, скопировать рисунок так, чтобы вписать формулу не получается, но скачав пример, то рисунок, который менялся с формулой совершенно другого формата, пока не знаю в чем дело, но буду эксперементировать
20.09.2013 15:49:43
Народ, я нашел в чем проблема!
суть данной функции, которая представлена в примере, это создать рисунок, который будет полностью повторять то, что написано или нарисовано в конкретной ячейке, другими словами скриншот ячейки.
Данную функцию (лично я в своем excel 2007) получил следующим путем:
1) выбираем ячейку, которую хотим, чтобы наш рисунок повторял
2) тисним CTRL+V или же просто копировать
3) в меню "Главное => буфер обмена => вставить.." нажимаем на стрелочку, так чтобы выскочило дополнительное меню и выбираем "Как рисунок => вставить связь с рисунком".

Тем самым получаем рисунок, который ссылается на конкретную ячейку, у которого можно вбивать формулу (по идее формула должна ссылаться только на какую то ячейку (чтобы было с чего делать скриншот), то есть если вбить формулу итог вычисления которой будет 16 или 9999, то выдаст ошибку неверная ссылка. Именно по этой причине надо использовать формулу, которую использует автор данной статьи (  =смещь....) а не, например =впр).
Данный рисунок, как правило, получаем поверх копируемой ячейки.

Надеюсь довольно понятно разъяснил.
26.09.2013 09:55:11
Спасибо,  Maksim Barilov! Всё работает, только  
2) тисним CTRL+V или же просто копировать
CTRL+С  :)
10.10.2013 19:14:59
Спасибо! Всё работает.Отличная статья.Подскажите,как сделать чтобы при выборе наименования товара из выпадающего списка  получать в соседних  ячейках В и С габаритные размеры изделия (на пример:В-ширина,С-длина). Спасибо!
03.11.2013 17:04:36
Добрый день! Совсем недавно открыл для себя этот замечательный сайт и теперь восторгаюсь :)  Посмотрел видео, сделал. Класс! Хочу сделать небольшой коммент:
Выпадающий список в ячейке это хорошо, но порой гораздо интереснее, когда этот список реализован с помощью кнопки ( через вкладку разработчик). В этом случае, нам не удастся воспользоваться функцией ПОИСКПОЗ, поскольку у нас не будет ячейки, а будет объект - выпадающий список. Что же делать?  Но все оказывается гораздо проще! Мы можно привязать объект выпадающий список к любой другой ячейке. В этом случае, в этой ячейке будет проставляться номер выбранной позиции относительно начала списка! А стало быть, можно ссылаться прямо на эту ячейку вместо использования не самой просто функции ПОИСКПОЗ. Надеюсь, кому-то будет полезно :)

И вопрос к аудитории:  На финише мы выделяли вставленную как картинка ячейку и в командной строке прописывали = Фото (динамический массив). Массив Фото по сути, задан формулой Смещ и т.д Но если в командной строке прописать эту самую формулу, заместо короткого "Фото" Excel ругается. Т.о сделать так, чтобы "протянуть" картинку вниз, чтобы, к примеру, она изменялась при изменении значения в соседнем столбце, у нас не получится? Или все же как то можно это сделать? Своеобразный аналог ВПР, но для картинок :)
04.11.2013 21:21:23
А у нас такое задание было на олимпиаде по ИКТ областного уровня за 10 класс.. За статью-урок спасибо, теперь знаем, как такое делать:D
29.11.2013 14:42:42
подскажите возможно ли изменить формулу если есть два листа - каталогов  с наименованиями и фотографиями товаров, что бы фотки также отображались через выпадающий список, но данные уже берутся с двух листов
04.12.2013 16:56:10
Подскажите, такая задача. В выпадающем списке написаны названия цветов, КРАСНЫЙ, СИНИЙ и т.д., как сделать что бы после выбора цвета соседняя ячейка закрашивалась в нужный цвет ? Или еще лучше было бы, что бы закрашивалась ячейка прямо в выпадающем списке в этот цвет (после выбора).
16.01.2014 07:14:01
условное форматирование вам в помощь (Ексел 2007 и старше)
Страницы: 1  2  
Наверх