Форум программистов, компьютерный форум, киберфорум
Delphi для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.88/48: Рейтинг темы: голосов - 48, средняя оценка - 4.88
0 / 0 / 0
Регистрация: 13.02.2013
Сообщений: 34

не работает GetActiveOleObject в Excel

29.03.2013, 20:12. Показов 10151. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
добрый день. не могу понять почему не работает
есть код
Delphi
1
2
3
4
5
6
7
8
try
  Excel := GetActiveOleObject('Excel.Application');
 except
   on EOLESysError do
  begin
  Excel := CreateOleObject('Excel.Application');
   end;
 end;
но, не смотря на обработчик ршибок, все равно выпадает ошибка EOLESysError 'Операция недоступна'
пробовал на ХР и 7, везде стоит 2003 офис и пакет обеспечения совместимости для 2007 офиса
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
29.03.2013, 20:12
Ответы с готовыми решениями:

Не работает с Excel 2003, работает с Excel 2007
Visual Studio 2008 SP1, проект MFC. В файле stdafx.h прописываю следующее для работы с Excel (тестировал в Excel 2007). #import...

Макрос для загрузки картинок - работал в Excel 2013, но не работает в Excel 2016
Добрый день! Имеется макрос который работал в Excel 2013, но не работает в Excel 2016. Помогите пожалуйста возобновить работу...

Работа с excel: 11 версия не работает с 2010 офисом, но работает с 2007, 2013
Имеются несколько Microsoft.Office.Interop.Excel.dll,которые используются для записи в excel документ. Проблема в том что 11 версия не...

7
 Аватар для Mawrat
13116 / 5897 / 1708
Регистрация: 19.09.2009
Сообщений: 8,809
29.03.2013, 21:35
GetActiveOleObject() подключается к активному OLE-объекту. Т. е, чтобы вызов прошёл без ошибок, в это время уже должен быть запущен экземпляр MS Excel - к нему произойдёт подключение. Если MS Excel в данный момент не запущен, то возникнет исключение EOLESysError. В этом случае представленный код запустит новый сеанс MS Excel и подключится к нему.
0
0 / 0 / 0
Регистрация: 13.02.2013
Сообщений: 34
29.03.2013, 22:10  [ТС]
в том-то и проблема что не срабатывает, а выпадает в ошибку
0
 Аватар для Mawrat
13116 / 5897 / 1708
Регистрация: 19.09.2009
Сообщений: 8,809
29.03.2013, 22:21
Тогда пока не понятно, в чём дело...

Добавлено через 3 минуты
Можно включить режим отладки библиотечных модулей и посмотреть на каком этапе возникает исключение:
Delphi
1
2
3
4
5
6
7
8
9
function GetActiveOleObject(const ClassName: string): IDispatch;
var
  ClassID: TCLSID;
  Unknown: IUnknown;
begin
  ClassID := ProgIDToClassID(ClassName);
  OleCheck(GetActiveObject(ClassID, nil, Unknown));
  OleCheck(Unknown.QueryInterface(IDispatch, Result));
end;
По этому можно будет примерно предположить в чём дело. - Возможно OLE объекты офиса неверно зарегистрированы в системе.
0
Пишу на Delphi...иногда
 Аватар для cotseec
1423 / 1278 / 286
Регистрация: 03.12.2012
Сообщений: 3,914
Записей в блоге: 5
29.03.2013, 22:31
запуск происходит под Delphi? если запустить скомпилированный экзешник из проводника?
1
0 / 0 / 0
Регистрация: 13.02.2013
Сообщений: 34
30.03.2013, 09:12  [ТС]
Цитата Сообщение от cotseec Посмотреть сообщение
запуск происходит под Delphi? если запустить скомпилированный экзешник из проводника?
хм, в delphi выдает ошибку, а при запуске экзешника все норм
0
 Аватар для Mawrat
13116 / 5897 / 1708
Регистрация: 19.09.2009
Сообщений: 8,809
30.03.2013, 11:59
Цитата Сообщение от Lendor Посмотреть сообщение
хм, в delphi выдает ошибку, а при запуске экзешника все норм
Потому что try - except используется - исключение перехватывается и гасится. При выполнении под отладчиком это исключение сначала перехватывает отладчик и показывается соответствующее сообщение об ошике. Потом исключение обрабатывается в разделе except - end.
1
0 / 0 / 0
Регистрация: 13.02.2013
Сообщений: 34
30.03.2013, 13:37  [ТС]
понятно, спасибо
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
30.03.2013, 13:37
Помогаю со студенческими работами здесь

Не работает Excel из VB
Ситуация. Добавляю в ссылки Excel. Устанавливаю все переменные. Файл открывается, но дальше никак. Set Ex = New...

QAxObject + Excel не работает
Снова здравствуйте уважаемые знатоки, вот какая проблема случилась, захотел попробовать через Qt файл .xlsx обработать, прочитал статьи на...

Help Excel Screenupdating не работает
Собственно сабж Все работает - формы, процедуры Но все отображается :( и соответственно медленно (книга большая) в начале -...

Не работает макрос Excel
Здравствуйте. Есть задача, нужен макрос который будет копировать указаные ячейки и указаной строки, и переносить их на новый лист. Я...

Почему не работает С++ с Excel...
Почему сервер на с++ работает с клиентом, написанным на обыкновенном VB(тот свободно создает нужный объект), и не работает Excel(не видит...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определенном условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru