В диаграммах Excel есть один небольшой минус. Если построить диаграмму на основе данных, которые планируется добавлять со временем, то по мере добавления данных в таблицу, на которой основана диаграмма, придется также менять диапазон данных для диаграммы, чтобы включить их в отображение. Либо сразу указать заведомо больший диапазон, но тогда диаграмма весьма некрасиво выглядит. Это не такая уж и проблема, если данные добавляются один раз в месяц. А если это необходимо делать каждый день? Или несколько раз в день?
Итак, у нас имеется таблица в столбцах A, B и С - Дата, Количество посетителей и Количество просмотров соответственно.
Данный вариант более сложен в реализации, но может быть использован в любой версии Excel и помимо этого в диаграмму можно добавить любой столбец таблицы.
Создаем на основании данной таблицы диаграмму. Для того, чтобы создать динамически обновляемую диаграмму, нам понадобиться создать три динамических именованных диапазона из таблицы данных:
- Жмем
Ctrl +F3 - В поле Диапазон(Refers to) пишем формулу
=СМЕЩ(Таблица!$A$2:$A$2;;;СЧЁТЗ(Таблица!$A$1:$A$1000);) - В поле Имя(Name) - желаемое имя для данного диапазона(в данном случае лучше давать понятное имя - имя ряда) - Дата.
Тоже самое делаем с двумя остальными рядами. В результате у нас получится три именованных диапазона:
- Дата
=СМЕЩ(Таблица!$A$2:$A$2;;;СЧЁТЗ(Таблица!$A$1:$A$1000);) - Количество посетителей
=СМЕЩ(Таблица!$B$2:$B$2;;;СЧЁТЗ(Таблица!$B$1:$B$1000);) - Количество просмотров
=СМЕЩ(Таблица!$C$2:$C$2;;;СЧЁТЗ(Таблица!$C$1:$C$1000);)
Теперь кликаем правой кнопкой мыши по диаграмме:
для Excel 2007-2010 - Выбрать данные(Select Data);
для Excel 2003 - Исходные данные(Source data).
Выбираем нужный ряд, нажимаем "Изменить" и вписываем имя динамического диапазона в качестве диапазона для данных этого ряда.
Важно: при замене диапазона заменить надо только адрес ссылки, а имя листа и книги оставить неизменными. Т.е. должно получиться - =Таблица!Дата или =Dinamic_Chart.xls!Дата
Жмем Ок. Все, теперь при добавлении данных в таблицу, данные в диаграмме тоже добавятся.
Это быстрый и просто способ, который рассчитан на то, что диаграмма строится на основании всех столбцов таблицы. Основан он на том, что Excel позволяет создавать такой объект, как таблица(в 2003 Excel это называется Список). Хоть такой объект есть и в 2003 версии, но в 2003 невозможно узнать имя этой таблицы без применения VBA.
Для начала потребуется создать так называемую "умную таблицу". Создать её можно двумя способами
- Выделить любую ячейку области данных, перейти на вкладку Вставка
(Insert) -Таблица(Table) - В появившемся окне согласиться с указанным диапазоном или выбрать свой
- Нажать OK
Выделить любую ячейку области данных
Выбрать команду на вкладке Главная
После этого идем в диспетчер имен(
это и есть нужная нам таблица.
Создаем диаграмму, правая кнопка мыши по области диаграммы:
для Excel 2007-2010 - Выбрать данные
для Excel 2003 - Исходные данные
Вписываем имя таблицы в качестве диапазона для данных диаграммы:
Нажимаем Ок. Теперь при расширении таблицы и добавлении строк эти данные будут автоматически добавлены и в диаграмму.
В примере ниже файл с реализацией обоими вариантами.
Tips_Chart_Dinamic_Chart.xls (29,5 КиБ, 10 118 скачиваний)
Так же см.:
Именованные диапазоны
Динамические именованные диапазоны
Щелкнул по диаграмме прав кнопкой -> исходные данные -> вкладка "диапазон данных" и ниже строка "Диапазон" туда я и вписываю название именованного диапазона, нажимаю ок. Там не написано для какого именно ряда. Кстати вместо СЧЕТЗ использовал СЧЕТ, т.к. у меня формула в том столбце от куда диаграмма берет данные. А вот формула которую я использовал:
=СМЕЩ(Мощность!$AE$2500;СЧЁТ(Мощность!$AE$2500:$AE$20000)-24;;24;)
На форумах рыскал, все сюда отправляют, так что если что не ругайтесь.)
То есть я вот.
Петрович, Вы назначаете диапазон для всей диаграммы. прочитайте внимательно статью - Вам надо создать несколько динамических диапазонов - для кадого ряда свой диапазон. А затем рядам назначить эти диапазоны:
Выбираем нужный ряд, нажимаем «Изменить» и вписываем имя динамического диапазона в качестве диапазона для данных этого ряда.
Дмитрий(Админ), Все, разобрался_) Спасибо большое.
Статья отличная! Спасибо автору! Все очень просто и доступно тому, кто умеет думать. Жаль,что диапазон сдвигается только при пустых ячейках, а если в ячейки вбита формула вроде =IF(F335>0;F335;""), то он это за пустую ячейку не считает и не сдвигается:( будем думать.
Добрый день.
Вы придумали как не считать "" графика
Здравствуйте!
Петрович, подскажите пожалуйста, как у Вас получилось разобраться со временем в диапазоне? чтобы оно не стояло на 00:00:00, а отображались значения в диаграмме и за другое время в сутках. Спасибо заранее.