|
2 / 2 / 0
Регистрация: 12.03.2011
Сообщений: 8
|
|
Public переменные - мистика12.03.2011, 20:36. Показов 8292. Ответов 13
Метки нет (Все метки)
Всем добрый день!
Сталкнулся с такой заморочкой: для того чтобы переменные были видны в различных формах, процедурах я объявил их в обычном модуле в Declarations как Public (кроме объявления переменных в модуле ничего нет). Все было нормально, все переменные были видны и прекрасно работали. Но потом по непонятным причинам, переменные перестали быть Public, причем массивы этот тип не потеряли О_о. Звучит как бред. Я пробовал запускать файл в разных версиях Excel, результат одинаков. Просто мистика какая-то! Буду благодарен за любые дельные советы в какую сторону можно копнуть, что проверить, а то запарился уже искать причину
0
|
|
| 12.03.2011, 20:36 | |
|
Ответы с готовыми решениями:
13
Подвижные ЭУ и Public-переменные моего типа в форме Почему не видны Public процедуры и переменные из других проектов Make sure class name exists, is public, and has an empty constructor that is public |
|
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 | |
|
0
|
|
|
2309 / 1541 / 115
Регистрация: 13.06.2009
Сообщений: 5,575
|
|
| 12.03.2011, 21:42 | |
|
0
|
|
|
6644 / 1511 / 169
Регистрация: 09.01.2010
Сообщений: 4,298
|
|
| 12.03.2011, 23:09 | |
|
0
|
|
|
1905 / 782 / 31
Регистрация: 11.02.2010
Сообщений: 1,567
|
||
| 13.03.2011, 09:25 | ||
|
кроме того, тебе, 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
|
|
| 14.03.2011, 19:43 | |
|
Помогаю со студенческими работами здесь
14
Exporting non-public type through public API Как из потока public void X1() извлечь значение string в public void X2()
Как в "public void G2" получить значение string из "public void G1" Мистика) Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
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. Пошагово создадим проект для загрузки изображения. . .
|