Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2005.10.09;
Скачать: CL | DM;

Вниз

Загрузка потока в Excel   Найти похожие ветки 

 
Dmitrich   (2005-08-31 19:19) [0]

Уважаемые, мастера, подскажите можно ли текст файла Excel из переменной типа AnsiString или потока запустить в Excel-е не сохраняя его на компьютер?


 
Fay ©   (2005-08-31 19:21) [1]

2 Dmitrich   (31.08.05 19:19)
перефразируй вопрос


 
Dmitrich   (2005-08-31 19:51) [2]

Есть БД в которой хранятся Excel файлы. И при необходимости их нужно открывать. На данный момент это у меня реализовывается следующим образом:
...
var
 BlobF:AnsiString;
...
BlobF:=Form1.IBQuery1.Fields[2].AsString;
// BlobF сохраняется на жестком диске
ShellExecute(application.MainForm.Handle,pchar("open"),pchar("DOC.xls"+fileStr),nil,pchar("DOCS.xls "),sw_shownormal);

Нужно это сделать без сохранения на ЖД


 
Fay ©   (2005-08-31 20:31) [3]

2 Dmitrich   (31.08.05 19:51) [2]
Никак.


 
Внук ©   (2005-09-01 08:46) [4]

Можно через TOleContainer.


 
Dmitrich   (2005-09-12 20:40) [5]

Внук, можешь по подробней?


 
Внук ©   (2005-09-16 15:56) [6]

Могу, только прошу подождать до следующей недели - очень занят...


 
Внук ©   (2005-09-19 12:36) [7]

У меня ситуация похожая - надо из BLOB-полей БД Oracle доставать хранящиеся там документы Excel и открывать их пользователю. Создание промежуточных файлов на диске нежелательно по соображениям защиты информации.
 Сделал так. Есть компонент TOleContainer, у него метод LoadFromStream. В качестве аргумента принимается TStream, или, разумеется, его наследник. К базе доступ осуществляется через DOA, в его составе есть класс TLOBLocator. Это наследник TStream, у которого, среди прочего, перекрыт метод Read. Если для InterBase такого класса нету, можно его реализовать самому.
 В TOleContainer Excel работает в режиме ограниченной функцицональности, но я добился всего, что было нужно. Можно пользователю предоставить возможность открывать из TOleContainer полнофункциональный Excel в отдельном процессе - смотри свойства AllowActiveDoc, AllowInPlace, AutoActivate.
 В итоге считывание документа из базы сводится к строчке вроде
 FOleContainer.LoadFromStream(DataStream),
где DataStream - TLobLocator из DOA, "нацеленный" предварительно на нужную запись и нужное поле. И никаких промежуточных файлов.


 
Dmitrich   (2005-09-19 16:43) [8]

Да, Внук, я почти во всём разобрался. Я тоже решил использовать OleContainer, внутри приложения! Это даже лучше чем открывать файлы отдельно. Теперь борюсь с Toolbars, т. к. он их кидает куда попало и тяжело скрыть без последствий! Но задача почти решена!!!



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

Текущий архив: 2005.10.09;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.026 c
1-1126947438
Piter
2005-09-17 12:57
2005.10.09
Непонятка с директивами компилятора


1-1127052828
Андрей Молчанов
2005-09-18 18:13
2005.10.09
Узнать, что главная форма является активной для приложения


1-1126781238
Aliv
2005-09-15 14:47
2005.10.09
установить ограничение после запятой


3-1125052170
erika
2005-08-26 14:29
2005.10.09
Работа с DATE


2-1125119779
Ivanov
2005-08-27 09:16
2005.10.09
Новый компонент