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

Public переменные - мистика

12.03.2011, 20:36. Показов 8292. Ответов 13
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем добрый день!
Сталкнулся с такой заморочкой: для того чтобы переменные были видны в различных формах, процедурах я объявил их в обычном модуле в Declarations как Public (кроме объявления переменных в модуле ничего нет). Все было нормально, все переменные были видны и прекрасно работали. Но потом по непонятным причинам, переменные перестали быть Public, причем массивы этот тип не потеряли О_о. Звучит как бред. Я пробовал запускать файл в разных версиях Excel, результат одинаков. Просто мистика какая-то! Буду благодарен за любые дельные советы в какую сторону можно копнуть, что проверить, а то запарился уже искать причину
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
12.03.2011, 20:36
Ответы с готовыми решениями:

Подвижные ЭУ и Public-переменные моего типа в форме
Я добавил свой тип МестоположениеВидимостьКонтрола. Пытался добавить Public-переменные этого типа в форму для сохранения сведений о...

Почему не видны Public процедуры и переменные из других проектов
Почему не видны Public процедуры и переменные из других проектов, в которых нет Praive Option Explicit. Что в VBA Excel, что в VB. Ведь эта...

Make sure class name exists, is public, and has an empty constructor that is public
Здравствуйте, подскажите пожалуйста, в чем ошибка? Я нашел информацию, что тот класс где возникает эта ошибка, лучше сделать static . Вот...

13
2309 / 1541 / 115
Регистрация: 13.06.2009
Сообщений: 5,575
12.03.2011, 20:43
Vigo,
Option Explicit используете?
0
2 / 2 / 0
Регистрация: 12.03.2011
Сообщений: 8
12.03.2011, 21:02  [ТС]
Было без Option Explicit. Добавил в модуле в Declaration, но некоторые переменные в Private процедурах так и оставил необъявленными. Запускаю, по идее должен VBA ругнуться найдя необъявленную переменную, но ничего подобного!!! Как-будто, что написано в модуле, для него не существует (но массивов это не касается).
0
2309 / 1541 / 115
Регистрация: 13.06.2009
Сообщений: 5,575
12.03.2011, 21:10
Vigo,
Option Explicit нужно в каждом модуле писать.
0
2 / 2 / 0
Регистрация: 12.03.2011
Сообщений: 8
12.03.2011, 21:24  [ТС]
Так я и написал в модуле. У меня модуль всего один! И этот модуль содержит только объявление глобальных переменных, которые мне нужны в процедурах форм. Я и раньше так делал. Просто сейчас как-будто потерялась какая-то связь с модулем.
0
2309 / 1541 / 115
Регистрация: 13.06.2009
Сообщений: 5,575
12.03.2011, 21:25
Vigo,
в формах тоже надо.
0
6644 / 1511 / 169
Регистрация: 09.01.2010
Сообщений: 4,298
12.03.2011, 21:40
Цитата Сообщение от Busine2009 Посмотреть сообщение
Option Explicit нужно в каждом модуле писать.
с чего бы это ?
0
2309 / 1541 / 115
Регистрация: 13.06.2009
Сообщений: 5,575
12.03.2011, 21:42
Цитата Сообщение от gaw Посмотреть сообщение
с чего бы это ?
я проверил.
0
6644 / 1511 / 169
Регистрация: 09.01.2010
Сообщений: 4,298
12.03.2011, 23:09
Цитата Сообщение от Busine2009 Посмотреть сообщение
я проверил.
сори, я не знал, что ваша проверка, - это истина в последней инстанции
0
 Аватар для ironegg
1905 / 782 / 31
Регистрация: 11.02.2010
Сообщений: 1,567
13.03.2011, 09:25
Цитата Сообщение от Busine2009 Посмотреть сообщение
в формах тоже надо.
имеется в виду не в формах, а в модулях форм. http://www.microsoft.com/Rus/M... yle/9.mspx
кроме того, тебе, Vigo, не нужен модуль только лишь для объявления переменных. объяви глобальные переменные в любом другом существующем модуле. от этого они не станут менее глобальными
0
2309 / 1541 / 115
Регистрация: 13.06.2009
Сообщений: 5,575
13.03.2011, 09:34
ironegg,
глобальные переменные можно объявлять только в модулях стандартного типа.
0
2 / 2 / 0
Регистрация: 12.03.2011
Сообщений: 8
14.03.2011, 05:36  [ТС]
Спасибо всем откликнувшимся.Проблему по прежнему не решил. Option Explicit конечно помогает от многих "мистических" ошибок, но убивает в моей ситуации другое: все прекрасно !!!работало!!! и без Option Explicit, т.е. глобальные переменные описанные в одном единственном имеющемся стандартном модуле (не класса) были видны во всех процедурах форм и нормально справлялись со своей задачей. Просто потом в "непрекрасный" момент времени стало так я описал. Т.е., имеется модуль с описанием Public переменных или его нет - все равно. Правдо это не каснулось объявленных массивов (заданы с указанием размерности). Да, у меня было еще пару модулей, которые создавал макрорекордер, но я их удалил. Переменных там вообще не было, а их объявлений тем более. Не могло же это повлиять как-то. Ладно, покопаю дальше, уже просто спортивный интерес появился.

Добавлено через 9 часов 36 минут
Вот я и докопался до причины такого явления Public переменных. Натолкнула на это тема на этом форуме "Excel 2003. Глобальная переменная = 0 в Worksheet_SelectionChange". Дело в том, что я как и автор указанной темы создал кнопку на рабочем листе только для перехода на другой нужный лист. Процедура перехода (строка Worksheets(1).Select) событие Click кнопки находилась на листе с этой кнопкой. Убрав кнопку и процедуру, перписав файл, закрыв и загрузив его снова получил вновь работающие Public переменные указанные в модуле!!! Теперь вопрос, почему внедрение кнопки на рабочий лист так влияет на поведение глобальных переменных?
1
2309 / 1541 / 115
Регистрация: 13.06.2009
Сообщений: 5,575
14.03.2011, 11:05
Vigo,
напишите код, чтобы я мог у себя на компьютере создать такую же ситуацию, что переменные себя так ведут.
0
2 / 2 / 0
Регистрация: 12.03.2011
Сообщений: 8
14.03.2011, 19:43  [ТС]
Докопался до истины наконец-то. Кому интересно вот ссылка на эту тему на одном из форумов:[ссылка удалена модератором - п. 3.7 правил] Точно говорят: век живи-век учись. Кто бы мог подумать, что есть такая особенность при внедрении на лист ActiveX элементов. Спасибо всем участникам дискуссии, всем кодов без багов

Добавлено через 7 часов 46 минут
Вот ссылка на то, что было удалено модератором, правда уже на этом форуме: Excel 2003. Глобальная переменная = 0 в Worksheet_SelectionChange
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
14.03.2011, 19:43
Помогаю со студенческими работами здесь

Exporting non-public type through public API
Exporting non-public type through public API Показывает возле метода класса. В чем причина данного предупреждения? Как от него...

Как из потока public void X1() извлечь значение string в public void X2()
Как из: public void X1() \\Запускается из потока (Process = new Thread(X1)) { //Какой то алгоритм string str =...

Реализовать класс Студент с публичным (public) полем Имя и публичным (public) методом print(), который выводит поле имя
Реализовать класс Студент с публичным (public) полем Имя и публичным (public) методом print(), который выводит поле имя на экран....

Как в "public void G2" получить значение string из "public void G1"
В "public void G1" имеется string str = "123", как в "public void G2" получить значение string из "public void G1"? str - постоянно...

Мистика)
Привет всем.Такая проблема: У меня есть форма,допустим Form1 Когда ее вызывать кодом,то появляется форма,и тупо виснет вся прога,если...


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

Или воспользуйтесь поиском по форуму:
14
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера 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. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru