Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Основная";
Текущий архив: 2003.07.10;
Скачать: [xml.tar.bz2];

Вниз

Работа с Excel через OLE   Найти похожие ветки 

 
Koloto   (2003-06-27 09:14) [0]

Приложение (правда, на Билдере 5.0) создает объект Excelя и работает с ним. После конца работы (даже после закрытия приложения) Ексель остается открытым, чтоб юзер мог посмотреть, что там прога натворила.
Приложение многопоточное, объект Екселя создается через CreateOleObject, вся работа с ним ведется через Variant путем вызова OLE-шных функций и свойств, все внутри одного потока.
Пока Ексель остается открытым, все работает отлично. Но как только юзер закрывает его (независимо от того, открыто еще приложение или нет), вылетает ошибка:

"Инструкция по адресу ... обратилась к памяти по адресу ... Память не может быть "read" "

Не подскажите, в чем может быть проблема?


 
kudatsky   (2003-06-27 09:24) [1]

Если у тебя Excel 97, инстолируй Excel 97 SR2,
а лучше 2000


 
andrey_pst   (2003-06-27 10:49) [2]

ссылки на все объекты Excel"я убиваешь ?
например,
xlsApp := UnAssigned;


 
Koloto   (2003-06-27 12:05) [3]

Спасибо всем.
Проблема решилась путем использования OleInitialize / OleUninitialize. Оказывается при работе с OLE в многопоточном приложении надо вызывать эти функции.
Интересно, что в борландовском хелпе (по крайней мере к Билдеру 5.0) ничего про это не сказано.



Страницы: 1 вся ветка

Форум: "Основная";
Текущий архив: 2003.07.10;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.45 MB
Время: 0.194 c
1-31191
ОРЕН
2003-06-27 21:24
2003.07.10
Вставить строку в чужую программу.


1-31353
_Dimitry
2003-06-27 10:18
2003.07.10
как разрешить пользователю вводить в Edit только цифры и запятую


4-31579
Still Swamp
2003-05-08 18:46
2003.07.10
Thread


1-31267
EgorKA
2003-06-30 01:37
2003.07.10
Добавление текста в файл...


1-31305
Zn
2003-06-26 15:22
2003.07.10
Как узнать, существует ли элемент?





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский