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

Вниз

открыт ли уже *.xls файл   Найти похожие ветки 

 
knastya   (2006-11-09 02:09) [0]

Подскажите, пожалуйста.
Стоит задача записать данные из Дельфи в экселевскую таблицу. Если вдруг таблица уже открыта в самом экселе на момент записи, данные не будут сохранены в ней. Соответсвенно, перед тем, как записывать в таблицу, хотелось бы узнать, не открыта ли она уже.
Делаю:

ExcelApp := CreateOleObject("Excel.Application");

b:=false;
i:=1;
n:=ExcelApp.Application.WorkBooks.count;
while (not b) and (i<=n) do
 begin
   b:=(ExcelApp.Application.WorkBooks[i].Fullname= fileName);
   inc(i);
 end;

Так вот, n=0, если эксель запущен и в нем открыты таблицы.
А как мне тогда увидеть, что файл открыт?


 
ЮЮ ©   (2006-11-09 07:30) [1]

вместо inc(i); следует if not b then inc(i);
Не стоит терять с таким трудом найденный индекс

if b then
 oткрыт ExcelApp.Application.WorkBooks[i]

на n можно и не смотреть


 
MetalFan ©   (2006-11-09 08:19) [2]

сначала
GetActiveOleObject("Excel.Application")
если что-то вернуло - то это запущенный экземпляр excel... возможно с открытыми файлами


 
umbra ©   (2006-11-09 13:08) [3]

лучше записать данные в новую книгу, закрыть ее, попытаться удалить файл со старыми данными. Если он открыт, то удалить его не удастся. Если закрыт, то он удалится и можно переименовывать новый файл. Что-то наподобие

if FileExists(oldfile) then
 repeat until DeleteFile(oldfile);
RenameFile(oldfile, newfile);


Пользоваться приведенным кодом не стоит, это только иллюстрация.


 
umbra ©   (2006-11-09 13:17) [4]

прошу прощения, конечно же

RenameFile(newfile, oldfile);


 
knastya   (2006-11-09 22:22) [5]

to [2]
Спасибо, заработало.
Правда не понимаю, как теперь отсоединится от excel, чтобы его при этом не закрыть (ну ведь с ним кто-то предположительно работает).

ExcelApp.Application.Quit; <----вот здесь закрывается
ExcelApp:=unassigned;



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

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

Наверх





Память: 0.46 MB
Время: 0.047 c
4-1155739454
webpauk
2006-08-16 18:44
2006.12.24
Проверка строковой переменной


2-1165083215
Mozgan
2006-12-02 21:13
2006.12.24
Как узнать имя?


15-1164984386
grisme
2006-12-01 17:46
2006.12.24
UTF-8


15-1165010827
ProgRAMmer Dimonych
2006-12-02 01:07
2006.12.24
Затронули тут с Колдуном тему ещё до того как...


8-1145691384
QuickFinder
2006-04-22 11:36
2006.12.24
объединение WMV-файлов





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
Английский Французский Немецкий Итальянский Португальский Русский Испанский