242 / 35 / 8
Регистрация: 05.05.2012
Сообщений: 521
1

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

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

Author24 — интернет-сервис помощи студентам
Здравствуйте!
Я создаю 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
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
27.03.2013, 18:33
Ответы с готовыми решениями:

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

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

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

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

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

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

Кстати, а с чего это процессы будут накапливаться-то? Программа запускается много раз? Тогда искать уже запущенный экземпляр Excel-я (GetActiveOleObject, если не нашел - только тогда CreateOleObject, эта связка очень часто используется, поиск в разделе Билдера выведет тебя на пример кода), тогда при многократном запуске программы в памяти будет висеть один и тот же процесс.
1
242 / 35 / 8
Регистрация: 05.05.2012
Сообщений: 521
28.03.2013, 17:06  [ТС] 3
Спасибо!!! GetActiveOleObject - как раз то, что я хотела)) А с CreateOleObject не получалось, потому что запускаю программу из экселевской книги
0
242 / 35 / 8
Регистрация: 05.05.2012
Сообщений: 521
31.03.2013, 12:57  [ТС] 4
Что-то не могу сообразить, как теперь лист добавить в уже открытый файл
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
32933 / 21258 / 8161
Регистрация: 22.10.2011
Сообщений: 36,517
Записей в блоге: 8
03.04.2013, 13:54 5
Лучший ответ Сообщение было отмечено volvo как решение

Решение

C++
1
Book = Application.OlePropertyGet("ActiveWorkbook");
, и работай с ней.
1
242 / 35 / 8
Регистрация: 05.05.2012
Сообщений: 521
03.04.2013, 16:27  [ТС] 6
Спасибо!
0
03.04.2013, 16:27
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
03.04.2013, 16:27
Помогаю со студенческими работами здесь

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

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

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

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

Excel висит в процессах после выполнения
Excel.Application excelApp = new Excel.Application(); Excel.Workbook workBook; ...

Не закрывается Excel после выполнения нужных действий в VB 6.0
Здравствуйте! Помогите, пожалуйста разобраться. Я в Visual Basic 6.0 открываю приложение...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru