Изменение данных в ячейке через ЕНТЕР

Программирование на Visual Basic, главный форум. Обсуждение тем программирования на VB 1—6.
Даже если вы плохо разбираетесь в VB и программировании вообще — тут вам помогут. В разумных пределах, конечно.
Правила форума
Темы, в которых будет сначала написано «что нужно сделать», а затем просьба «помогите», будут закрыты.
Читайте требования к создаваемым темам.
ForYou
Начинающий
Начинающий
 
Сообщения: 13
Зарегистрирован: 12.04.2004 (Пн) 13:26

Изменение данных в ячейке через ЕНТЕР

Сообщение ForYou » 14.04.2004 (Ср) 9:53

Подскажите пожалуйста. Есть несколько записей из таблицы в екселе. Необходимо чтобы при изменении данных в ексели данные поменялись в таблице. Делаю так
Код: Выделить всё
Private Sub Worksheet_Change(ByVal target As Range)
Dim Row, Col As Integer
Dim MyValue As String
Row = target.Row
Col = target.Column
Application.OnKey "ENTER", UpdateFunc Key,Value
End Sub

получаю error. Как правильно реализовать чтоб после изменения данных в ячейки данные обновлялись по результату нажатия клавиши Ентер. Если же нажата другая кнопка то вернуть первоначальные данные? Заранее спасибо

GSerg
Шаман
Шаман
 
Сообщения: 14286
Зарегистрирован: 14.12.2002 (Сб) 5:25
Откуда: Магадан

Сообщение GSerg » 14.04.2004 (Ср) 10:03

Не знаю, можно ли переопределить энтер, не буду пробовать :)
Но, в любом случае, не "ENTER", а "{ENTER}". Второй же параметр (ты думал, это function pointer? Эх, если бы) - это строка, содержащая имя функции. У тебя это "UpdateFunc". И никаких параметров в этом случае.
Как только вы переберёте все варианты решения и не найдёте нужного, тут же обнаружится решение, простое и очевидное для всех, кроме вас

ForYou
Начинающий
Начинающий
 
Сообщения: 13
Зарегистрирован: 12.04.2004 (Пн) 13:26

...

Сообщение ForYou » 14.04.2004 (Ср) 10:36

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

Cyrax
Cyberninja
Cyberninja
Аватара пользователя
 
Сообщения: 891
Зарегистрирован: 25.04.2002 (Чт) 21:20
Откуда: Magnitogorsk, Russia

Сообщение Cyrax » 14.04.2004 (Ср) 11:21

проблема заключается в том, как у тебя написан код события Change

для начала объявление переменных
Dim Row, Col As Integer

переменная Row имеет тип Variant, переменная Col - Integer

второе: Application.OnKey "ENTER", UpdateFunc Key,Value
где скобки, я вас спрашиваю
должно быть:
Application.OnKey "{ENTER}", UpdateFunc(Key,Value)
Ты это ему расскажи. Я уже пять болтов отвинтил, и конца не видно... (озадаченно) А это в какую сторону тянуть? Ну-ка... Ага, этот был лишний, этот вообще не отсюда, и этот... Точно, два болта.

Welcome to IRC


Вернуться в Visual Basic 1–6

Кто сейчас на конференции

Сейчас этот форум просматривают: AhrefsBot, Yandex-бот и гости: 22

    TopList