На главную Наши проекты:
Журнал   ·   Discuz!ML   ·   Wiki   ·   DRKB   ·   Помощь проекту
ПРАВИЛА FAQ Помощь Участники Календарь Избранное RSS
msm.ru
! ПРАВИЛА РАЗДЕЛА · FAQ раздела Delphi · Книги по Delphi
Пожалуйста, выделяйте текст программы тегом [сode=pas] ... [/сode]. Для этого используйте кнопку [code=pas] в форме ответа или комбобокс, если нужно вставить код на языке, отличном от Дельфи/Паскаля.
Следующие вопросы задаются очень часто, подробно разобраны в FAQ и, поэтому, будут безжалостно удаляться:
1. Преобразовать переменную типа String в тип PChar (PAnsiChar)
2. Как "свернуть" программу в трей.
3. Как "скрыться" от Ctrl + Alt + Del (заблокировать их и т.п.)
4. Как прочитать список файлов, поддиректорий в директории?
5. Как запустить программу/файл?
... (продолжение следует) ...

Вопросы, подробно описанные во встроенной справочной системе Delphi, не несут полезной тематической нагрузки, поэтому будут удаляться.
Запрещается создавать темы с просьбой выполнить какую-то работу за автора темы. Форум является средством общения и общего поиска решения. Вашу работу за Вас никто выполнять не будет.


Внимание
Попытки открытия обсуждений реализации вредоносного ПО, включая различные интерпретации спам-ботов, наказывается предупреждением на 30 дней.
Повторная попытка - 60 дней. Последующие попытки бан.
Мат в разделе - бан на три месяца...
Модераторы: jack128, D[u]fa, Shaggy, Rouse_
  
> трабла с ExcelApp.WorkBook.SaveAs
    есть исходный код (простой как трусы по рубль-двадцать):

    ExpandedWrap disabled
       
      procedure TfrmXLSOLEMain.Navigate(Sender: TObject; Name: string);
      // навигацЫя по каталогу(ам)
      var
        lFileName : TFileName;
        lNewName  : TFileName;
        xls       : Variant;
        wb        : Variant;
        I, N      : Integer;
        sName     : string;
       
        function ExtractFileNameOnly(var AName: TFileName): string;
        var
          lExt : string;
        begin
          Result := ExtractFileName(AName);
          lExt   := ExtractFileExt(Result);
          if lExt <> '' then
            Delete(Result, Pos(lExt, Result), Length(lExt));
        end;
       
      begin
        lFileName := FShell.FileName;
        if not FileExists(lFileName) then
          Exit;
        if AnsiUpperCase(ExtractFileExt(lFileName)) <> '.XLS' then
          Exit;
        xls              := CreateOleObject('Excel.Application');
        xls.WorkBooks.Open(lFileName);
        wb               := xls.ActiveWorkBook;
        N                := wb.Worksheets.Count;
        for I := 1 to N do begin
          wb.Sheets[I].Activate;
          sName    := wb.Sheets[I].Name;
          lNewName := AnsiLowerCase(Format('%s%s_%s.txt', [ExtractFilePath(lFileName), ExtractFileNameOnly(lFileName), sName]));
          wb.SaveAs(FileName := lNewName, FileFormat := xlTextWindows);
        end;
        xls.EnableEvents := false;
        wb.Save;
        wb.Close;
        xls.Quit;
      end;


    сохраненение происходит в сроке
    wb.SaveAs(FileName := lNewName, FileFormat := xlTextWindows);

    перед выполнением строки
    wb.Close;
    Ёксель во всю глотку орет :

    +-----------------------------------------------------+
    | "сохранить изменения в файле <filename.txt> ?" |
    +-----------------------------------------------------+


    Суть траблы:
    файл УЖЕ сохранен, а Ёксель пытается его еще раз сохранить и при этом выводит вышеприведенную мессагу

    Кто знает как это можно обойти? заранее благодарен
    Сообщение отредактировано: ych_boriss -
      xls.DisplayAlerts := false;
      1 пользователей читают эту тему (1 гостей и 0 скрытых пользователей)
      0 пользователей:


      Рейтинг@Mail.ru
      [ Script execution time: 0,0162 ]   [ 15 queries used ]   [ Generated: 17.05.24, 03:52 GMT ]