Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.92/25: Рейтинг темы: голосов - 25, средняя оценка - 4.92
0 / 0 / 0
Регистрация: 07.10.2008
Сообщений: 6

От ячейки к ячейке (Worksheets('Лист2').Range(Ard).Copy Worksheets('Лист1').Cells(1, 8).Paste)

14.10.2008, 14:00. Показов 5350. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Пишу код:
Visual Basic
1
2
3
4
5
6
7
8
9
Private Sub CommandButton2_Click()
Val = ActiveCell.Value
Adr = ActiveCell.Address
End Sub
 
Private Sub CommandButton1_Click()
Worksheets('Лист2').Range(Ard).Copy 
Worksheets('Лист1').Cells(1, 8).Paste
End Sub
Нверное понятно что я хочу сделать !!!
(Выбираю ячейку тыкаю на Button2 потом значения заносятся в переменные, потом тыкаю на Button1 должно быть так: на втором листе комирует Value из ячейки эквивалентной первой по адресу и вставляет на Лист1 в ячейку 1,8 ) В идеале должно быть так, но че-то не выходит !!!

Кто знает как ето сделать, или что исправить ???
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
14.10.2008, 14:00
Ответы с готовыми решениями:

With Worksheets('Лист1') TestVvod Obl:=.Range(.Cells(x,y),.Cells(x+5,y+10)) end with
Пожалуйста, ну откликнитесь умельцы!!! Обращаюсь к процедуре TestVvod Obl:='C5:K32' - срабатывает, а если With Worksheets('Лист1') ...

Не может открыть файл. Ошибка 9 (Worksheets('aaa').Cells(1, 1) = Workbooks(curr_path).Worksheets('2').Cells(1, 1))
Подскажите, пожалуйста, почему так работает : Worksheets('aaa').Cells(1, 1) = Workbooks(curr_path).Worksheets('2').Cells(1, 1) ...

ThisWorkbook.Worksheets('Table').Range(Cells(i, 9), Cells(i, 12)).Select Selection.Delete Shift:=xlUp Ошибка 1004
Помню я с этим уже сталкивался, но забыл как выкрутился. ThisWorkbook.Worksheets('Table').Range(Cells(i, 9), Cells(i, 12)).Delete...

3
Comanche
14.10.2008, 14:46
Во-первых, нельзя назвать переменную как 'Val' - это имя занято VBA-функцией. Во-вторых, зачем она вам нужна?! Вы же пишете, что отталкиваетесь только от АДРЕСА ячейки листа 'Лист1'.

Вот исправленный код, работающий с буфером обмена:
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
' Поместите в МОДУЛЬ:
Public Adr
'
Sub Main()
  UserForm1.Show 0
End Sub
'
' Поместите в ФОРМУ:
'
Private Sub CommandButton2_Click()
  Adr = ActiveCell.Address
End Sub
 
Private Sub CommandButton1_Click()
  Worksheets('Лист2').Range(Adr).Copy
  Worksheets('Лист1').Activate ' вставить из буфера можно только на активный лист
  Worksheets('Лист1').Cells(1, 8).Select ' выбираем ячейку для вставки
  ActiveSheet.Paste ' метод Paste применим к объекту WorkSheet, но не к Range
End Sub
А вот изменения в коде процедуры CommandButton1_Click(), если не использовать буфер обмена, - на случай, если вам надо переносить только значения (без форматирования):
Visual Basic
1
  Worksheets('Лист1').Cells(1, 8) = Worksheets('Лист2').Range(Adr)
(это единственная строка, которая будет в этой процедуре)
Comanche
14.10.2008, 23:19
Вы пишете:
Visual Basic
1
Worksheets('Лист2').Range(Ard).Copy
Может быть, всё-таки, должно быть Range(Adr), а не Range(Ard) ?!
3 / 3 / 0
Регистрация: 16.01.2008
Сообщений: 359
15.10.2008, 13:32
насчет совпадения имени переменной VAR с именем функции это верно, но вот ведь какая штука , переменные VAR и ADR ты инициализируешь в одном Sub-е а пытаешься их использовать в другом , но есть такая штука как 'ОБЛАСТЬ ВИДИМОСТИ ПЕРЕМЕННОЙ' это значит что переменная проинициализированная (а значит и автоматически объявленная) в одной процедуре НЕ БУДЕТ достпна в другой процедуре т.е. в Sub-е. Для этого нужно объявить обе твои переменные ГЛОБАЛЬНЫМИ c помощью оператора DIM и желательно с суффиксом AS после имени переменной за которым указывается ТИП переменной. Объявление выглядит так
DIM adr AS String - например и должно распологаться В САМОЙ ПЕРВОЙ строке модуля, эта область носит название Global Declaration
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
15.10.2008, 13:32
Помогаю со студенческими работами здесь

Worksheets.Copy но БЕЗ формул и просто картинки, или варианты
Добрый день! Наткнулся на проблему( Имеется рабочий код, который копирует лист из файла TITLE.xlsx в файл file.xlsx, присвоив...

Глюк при копировании листов: wsTemplate.Copy after:=OutputWB.Sheets(OutputWB.Worksheets.Count)
Странный глюк - VBA не выдает никакой ошибки, просто останавливается после выполнения этой строки, причем копирования не происходит. ...

Как Лист1 Range("A1:I68") и Лист2 Range("A1:I68") подать на двустороннюю печать ?
Подскажите пожалуйста. Есть книга Excel в ней два листа. Как Лист1 Range("A1:I68") и Лист2 Range("A1:I68") подать на...

Копирование Range методами Copy Paste без формул
Копирую ячейку из одной книги в другую обычными метода Copy Paste, текст которой имеет форматирование: часть слов, к примеру, выделены...

Cut, Copy, Paste, Select All в режиме редактирования ячейки DataGridView
Подскажите, возможно ли это реализовать. Своё ContextMenuStrip1 в режиме редактирования ячейки у меня работает. Есть такое решение: ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! */ #include <iostream> #include <stack> #include <cctype>. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru