Форум программистов, компьютерный форум, киберфорум
C/C++
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.54/13: Рейтинг темы: голосов - 13, средняя оценка - 4.54
 Аватар для Simply me
244 / 37 / 8
Регистрация: 05.05.2012
Сообщений: 521

Оставить после выполнения программы книгу Excel открытой

27.03.2013, 18:33. Показов 2831. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!
Я создаю Ole объект:
C++
1
Application=CreateOleObject("Excel.Application");
Открываю книгу Excel, используя OleProcedure:
C++
1
2
Books = Application.OlePropertyGet("Workbooks");
Books.OleProcedure("Open", path1);
Дальше считываю данные, записываю результат в эту же книгу.
Потом убиваю процесс:
C++
1
Application.OleProcedure("Quit");
Скажите, пожалуйста, как сделать так, чтобы программа не закрывала приложение, чтобы после выполнения программы книга оставалась открытой?
Если просто закомменитировать строку
C++
1
Application.OleProcedure("Quit");
то процессы будут накапливаться в системе
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
27.03.2013, 18:33
Ответы с готовыми решениями:

После выполнения макроса не закрывает книгу
Добрый день, Возникла проблема закрытии книги при использование шедулера. То есть, При отрывание файл пользователем срабатывает...

Оставлять объект в памяти в открытой книге Excel после завершения всех макросов
Создал пользовательский класс для объекта, в который я считываю исходные данные. Процесс их считывания и преобразования занимает...

Результат выполнения программы в консоли пропадает после выполнения скрипта
нужно отпарсить файл , но мне надо видеть что выводит сценарий , иначе мне его неотладить. Запускаю файл вот так python index.py

5
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33398 / 21508 / 8236
Регистрация: 22.10.2011
Сообщений: 36,906
Записей в блоге: 12
28.03.2013, 01:56
То есть, то, что открытая книга требует работающего процесса - понятно? Вот и выбирай, либо процессы не накапливаются (но тогда и книг нет), либо остается плюс один процесс к тому, что было до запуска программы, зато книга не закрылась.

Из воздуха Excel не может держать Workbook открытым, ему, блин, работающий процесс подавай.

Кстати, а с чего это процессы будут накапливаться-то? Программа запускается много раз? Тогда искать уже запущенный экземпляр Excel-я (GetActiveOleObject, если не нашел - только тогда CreateOleObject, эта связка очень часто используется, поиск в разделе Билдера выведет тебя на пример кода), тогда при многократном запуске программы в памяти будет висеть один и тот же процесс.
1
 Аватар для Simply me
244 / 37 / 8
Регистрация: 05.05.2012
Сообщений: 521
28.03.2013, 17:06  [ТС]
Спасибо!!! GetActiveOleObject - как раз то, что я хотела)) А с CreateOleObject не получалось, потому что запускаю программу из экселевской книги
0
 Аватар для Simply me
244 / 37 / 8
Регистрация: 05.05.2012
Сообщений: 521
31.03.2013, 12:57  [ТС]
Что-то не могу сообразить, как теперь лист добавить в уже открытый файл
C++
1
2
3
4
Books = Application.OlePropertyGet("Workbooks");
Book=                    //Books.OleFunction("Open",path1);
Sheets = Book.OlePropertyGet("Worksheets");
Sheet=Sheets.OleFunction("Add");
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33398 / 21508 / 8236
Регистрация: 22.10.2011
Сообщений: 36,906
Записей в блоге: 12
03.04.2013, 13:54
Лучший ответ Сообщение было отмечено volvo как решение

Решение

C++
1
Book = Application.OlePropertyGet("ActiveWorkbook");
, и работай с ней.
1
 Аватар для Simply me
244 / 37 / 8
Регистрация: 05.05.2012
Сообщений: 521
03.04.2013, 16:27  [ТС]
Спасибо!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
03.04.2013, 16:27
Помогаю со студенческими работами здесь

Как из программы создать книгу Excel
Помогите разобраться как из программы создавать файлы книг ЭксЭля. Очень надо. Заранее спасибо...

Раскрывающееся меню с JS, как оставить открытой активную категорию?
Всем привет! Помогите пожалуйста решить проблему. Менюхой управляет скрипт, который по клику делает подкатегорию видимой. Как сделать...

Как в книгу Excel записать много листов не выходя из программы ?
Господа, Всем доброго дня !!! Нужна очень Ваша помощь. Каким образом используя программный код VB, в книгу Excel записать например...

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

Как в офисе 97 закрыть только форму кнопкой, а Вордбук оставить открытой-активной?
Как в офисе 97 закрыть только форму кнопкой, а Вордбук оставить открытой-активной? Спасибо


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru