|
0 / 0 / 0
Регистрация: 03.08.2009
Сообщений: 36
|
|
Перенос форм из VBA в VB24.10.2010, 12:40. Показов 3727. Ответов 9
Метки нет (Все метки)
Нужен совет.
Есть небольшое приложение, оракловая база данных, и клиентская часть, написанная на VBA в Excel. Начиная с некоторого момента, столкнулся со следующй проблемой: иногда, после добавления очередной кнопки, Excel выдаёт стандартную ошибку 'Приложение будет закрыто', и то же самое при любой попытке открыть этот сохраненный файл.Пробовал запускать с разных компьютеров, такая же ошибка. Приходится поднимать старый вариант, и делать всё заново. Поискал в инете, есть мнение, что это из-за размера файла (у меня он 2,5 Мб). Я его облегчал переносом всех форм и классов в новый файл до 1,6 Мб, но через некоторое время начинается тоже самое. Можно было бы разбить на несколько модулей, но в силу разных причин не хотелось бы так делать. У меня появилась мысль перенести всё приложение на Visual Basic. Раньше я с ним не работал. В связи с этим возникает два вопроса: 1. Возможно написать на нем такую программу, которая в своей работе использовала бы листы Excel,и при этом не выдавала подобных глюков. 2. Возможно ли достаточно быстро (несколько дней) перенести все формы, модули, объекты из VBA в этот новый проект.
0
|
|
| 24.10.2010, 12:40 | |
|
Ответы с готовыми решениями:
9
Перенос форм VBA в VB.NET Перенос печатных форм с КА в УТ 11
|
|
2 / 2 / 1
Регистрация: 19.07.2007
Сообщений: 737
|
|
| 24.10.2010, 13:43 | |
|
Формы придется переделывать в ручную, а модули можно скопировать и кое-что исправив можно их использовать.
0
|
|
|
0 / 0 / 0
Регистрация: 03.08.2009
Сообщений: 36
|
|
| 24.10.2010, 17:17 [ТС] | |
|
Спасибо ! Попробую.
0
|
|
|
3 / 3 / 0
Регистрация: 12.07.2010
Сообщений: 128
|
|
| 24.10.2010, 20:48 | |
|
У меня тоже была прога, только в Word'е, 1,6 Mb, таких особых глюков не было, но все-же решил на VB перенести.
Было что-то около 20 форм, 30 модулей, строк по 300, и т.п. Я все формы и модули экспортировал, а затем импортировал в новый пустой проект. Каково было мое удивление, кода я откомпиликовал все это дело в exe-шку и запустил - все работало без особых переделок (так всякие Frm.Shoh на Frm.Show vbModal; UserForm_Initialize на Form_Load и т.п. поменял разом по всему проекту). Однако, если Вы собираетесь распространять прогу, имейте ввиду, что помимо 'обычного набора' нужна еще и библиотека FM20.DLL и FM20.OCA (Microsoft Forms 2.0 Object Library), которые сами по себе весят почти полтора мег. Вобщем, полюбовался, порадовался, а потом полностью переделал 'с нуля' все формы, чего и Вам желаю!!! PS: полностью переделанная версия получилась процентов на 30 меньше, хотя по ходу я еще вносил некоторые изменения и расшириял функционал.
0
|
|
|
0 / 0 / 0
Регистрация: 03.08.2009
Сообщений: 36
|
|
| 25.10.2010, 12:16 [ТС] | |
|
Спасибо! Вы меня вдохновили
![]() А зачем Вы переделывали все формы ? Они как-то плохо смотрелись после переноса ?
0
|
|
|
Comanche
|
|
| 25.10.2010, 12:41 | |
|
Просто кстати:
Майкрософт официально НЕ РЕКОМЕНДУЕТ использовать 'Microsoft Forms 2.0 Object Library' где-либо кроме VBA-проектов. Где-то в этом форуме даже ссылка была на сайт MS... |
|
|
Comanche
|
|
| 25.10.2010, 16:04 | |
|
Когда-то 'давным-давно' я решил перейти с языка WordBasic на язык VB 3.0
) Если кто не знает - WordBasic это предшественник VBA; он был встроен только в MS Word 6.0.Так вот, передо мной стояла схожая задача: написАть конвертер форм из формата WordBasic в формат VB 3.0. Прямо на VB 3.0 я его и написАл, где-то за 3-4 дня. С его помощью перегнал не один десяток форм, с сохранением вложенности контейнеров, отступов и размеров. Тупая, в общем-то, была работа - просто тогда только начинал изучать VB 3.0 и такие задачки были 'в кайф'. Если у вас очень много форм - то, м.б., пойти по такому же пути? У меня, кстати, по-моему даже код сохранился - могу выслать. Напрямую использовать его нельзя, конечно, но мало ли, может пригодится?! |
|
|
0 / 0 / 0
Регистрация: 03.08.2009
Сообщений: 36
|
|
| 31.10.2010, 20:20 [ТС] | |
|
'Просто кстати:
Майкрософт официально НЕ РЕКОМЕНДУЕТ использовать 'Microsoft Forms 2.0 Object Library' где-либо кроме VBA-проектов. Где-то в этом форуме даже ссылка была на сайт MS...' нигде не нашёл упоминания про это. Вот сейчас начал переносить на VB, и сразу же столкнулся с проблемой Combobox'a - я много где использовал возможность создания нескольких колонок в Combobox'е, а в VB можно использовать только одну колонку. Полазил в инете, нашёл только на этом сайте просьбу найти кряк к MultiColumn Combobox. Похоже, все-таки придется использовать 'Microsoft Forms 2.0 Object Library'... Скажите, чем может мне помочь такой конвертер ? Я сделал экспорт-импорт всех форм и классов, все импортировалось, но формы все легли в папку 'Designers'. Это означает, что я не смогу их прямо использовать ?
0
|
|
|
3 / 3 / 0
Регистрация: 12.07.2010
Сообщений: 128
|
|
| 01.11.2010, 09:16 | |
|
Не знаю что означает, но именно так и получается.
В принципе, у меня это никак не отражалось работе программы.
0
|
|
|
0 / 0 / 0
Регистрация: 03.08.2009
Сообщений: 36
|
|
| 02.11.2010, 18:08 [ТС] | |
|
Перенёс, вроде заработало. Всем большое спасибо за советы !
0
|
|
| 02.11.2010, 18:08 | |
|
Помогаю со студенческими работами здесь
10
Разработка форм VBA
VBA в Excel. Создание печатных форм Перенос форм Access в проект Visual Basic
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
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. Пошагово создадим проект для загрузки изображения. . .
|