Домашняя страница Undo Do New Save Карта сайта Обратная связь Поиск по форуму
МИР MS EXCEL - Гость.xls

Вход

Регистрация

Напомнить пароль

 

= Мир MS Excel/Перемещение диаграммы в видимую область - Мир MS Excel

Старая форма входа
  • Страница 1 из 1
  • 1
Модератор форума: китин, _Boroda_  
Мир MS Excel » Вопросы и решения » Вопросы по VBA » Перемещение диаграммы в видимую область (Макросы/Sub)
Перемещение диаграммы в видимую область
drugojandrew Дата: Понедельник, 31.08.2015, 15:18 | Сообщение № 1
Группа: Проверенные
Ранг: Форумчанин
Сообщений: 141
Репутация: 0 ±
Замечаний: 0% ±

Excel 2013
Добрый день.
Есть лист с диаграммой. На листе много значений, по которым диаграмма строится, и периодически они добавляются. Как сделать так, чтобы диаграмма перемещалась в видимую область листа при добавлении значений, или перемещалась к первой пустой ячейке в столбце, либо что-то в этом роде?
К сообщению приложен файл: 4545555.xls (41.5 Kb)
 
Ответить
СообщениеДобрый день.
Есть лист с диаграммой. На листе много значений, по которым диаграмма строится, и периодически они добавляются. Как сделать так, чтобы диаграмма перемещалась в видимую область листа при добавлении значений, или перемещалась к первой пустой ячейке в столбце, либо что-то в этом роде?

Автор - drugojandrew
Дата добавления - 31.08.2015 в 15:18
_Boroda_ Дата: Понедельник, 31.08.2015, 15:27 | Сообщение № 2
Группа: Модераторы
Ранг: Местный житель
Сообщений: 16675
Репутация: 6481 ±
Замечаний: 0% ±

2003; 2007; 2010; 2013 RUS
Так нужно?
В модуль листа
[vba]
Код
Private Sub Worksheet_Change(ByVal Target As Range)
        ActiveSheet.Shapes("Диаграмма 1").Top = Target.Top
End Sub
[/vba]
Диаграмма прыгает на ту строку, в которой произошло изменение.
Можно по другому событию или в другое место. Главное суть -
[vba]
Код
Диаграмма.Тор=Что_то.Тор
[/vba]
К сообщению приложен файл: 4545555_1.xls (43.5 Kb)


Скажи мне, кудесник, любимец ба’гов...
Платная помощь:
Boroda_Excel@mail.ru
Яндекс-деньги: 41001632713405 | Webmoney: R289877159277; Z102172301748; E177867141995
 
Ответить
СообщениеТак нужно?
В модуль листа
[vba]
Код
Private Sub Worksheet_Change(ByVal Target As Range)
        ActiveSheet.Shapes("Диаграмма 1").Top = Target.Top
End Sub
[/vba]
Диаграмма прыгает на ту строку, в которой произошло изменение.
Можно по другому событию или в другое место. Главное суть -
[vba]
Код
Диаграмма.Тор=Что_то.Тор
[/vba]

Автор - _Boroda_
Дата добавления - 31.08.2015 в 15:27
drugojandrew Дата: Понедельник, 31.08.2015, 16:53 | Сообщение № 3
Группа: Проверенные
Ранг: Форумчанин
Сообщений: 141
Репутация: 0 ±
Замечаний: 0% ±

Excel 2013
_Boroda_, спасибо.
Диаграмма.Тор=Что_то.Тор - а что можно вместо этого что-то, чтобы привязывать к последней пустой ячейке? Нужно все-таки по последней, т.к. когда я копирую большое количество значений на тот лист, то диаграмма перемещается к верхней вставленной ячейке, а не к нижней(((
 
Ответить
Сообщение_Boroda_, спасибо.
Диаграмма.Тор=Что_то.Тор - а что можно вместо этого что-то, чтобы привязывать к последней пустой ячейке? Нужно все-таки по последней, т.к. когда я копирую большое количество значений на тот лист, то диаграмма перемещается к верхней вставленной ячейке, а не к нижней(((

Автор - drugojandrew
Дата добавления - 31.08.2015 в 16:53
_Boroda_ Дата: Понедельник, 31.08.2015, 17:02 | Сообщение № 4
Группа: Модераторы
Ранг: Местный житель
Сообщений: 16675
Репутация: 6481 ±
Замечаний: 0% ±

2003; 2007; 2010; 2013 RUS
Или
[vba]
Код
ActiveSheet.Shapes("Диаграмма 1").Top = Target.Offset(Target.Rows.Count).Top
[/vba]
или ищем последнюю
[vba]
Код
ActiveSheet.Shapes("Диаграмма 1").Top = Range("B" & Rows.Count).End(xlUp).Top
[/vba]
[vba]
Код
ActiveSheet.Shapes("Диаграмма 1").Top = UsedRange(UsedRange.Count).Top
[/vba]


Скажи мне, кудесник, любимец ба’гов...
Платная помощь:
Boroda_Excel@mail.ru
Яндекс-деньги: 41001632713405 | Webmoney: R289877159277; Z102172301748; E177867141995
 
Ответить
СообщениеИли
[vba]
Код
ActiveSheet.Shapes("Диаграмма 1").Top = Target.Offset(Target.Rows.Count).Top
[/vba]
или ищем последнюю
[vba]
Код
ActiveSheet.Shapes("Диаграмма 1").Top = Range("B" & Rows.Count).End(xlUp).Top
[/vba]
[vba]
Код
ActiveSheet.Shapes("Диаграмма 1").Top = UsedRange(UsedRange.Count).Top
[/vba]

Автор - _Boroda_
Дата добавления - 31.08.2015 в 17:02
drugojandrew Дата: Понедельник, 31.08.2015, 17:19 | Сообщение № 5
Группа: Проверенные
Ранг: Форумчанин
Сообщений: 141
Репутация: 0 ±
Замечаний: 0% ±

Excel 2013
_Boroda_, спасибо, второй вариант то что надо!
 
Ответить
Сообщение_Boroda_, спасибо, второй вариант то что надо!

Автор - drugojandrew
Дата добавления - 31.08.2015 в 17:19
Мир MS Excel » Вопросы и решения » Вопросы по VBA » Перемещение диаграммы в видимую область (Макросы/Sub)
  • Страница 1 из 1
  • 1
Поиск:

Яндекс.Метрика Яндекс цитирования
© 2010-2024 · Дизайн: MichaelCH · Хостинг от uCoz · При использовании материалов сайта, ссылка на www.excelworld.ru обязательна!