線上訂房服務-台灣趴趴狗聯合訂房中心
發文 回覆 瀏覽次數:3021
推到 Plurk!
推到 Facebook!

Excel中斷的問題

缺席
mnsf
初階會員


發表:104
回覆:90
積分:48
註冊:2003-11-25

發送簡訊給我
#1 引用回覆 回覆 發表時間:2007-04-17 14:59:08 IP:61.30.xxx.xxx 訂閱
經常會將資料庫中的資料轉出至Excel,因為資料量很大,完全轉好可能需要花費一段時間,
但使用者在等待轉出的時間中可能會去開啟另一個已存在的Excel,
這時就會出現Error訊息(OLE error 800A03EC.),請問有方法可以避免嗎?
也就是說可以在Excel尚未轉出來的同時,去開啟另一個Excel嗎?

以下是一個簡單的轉Excel範例
uses comobj;
var FMsExcel,FWorkBook1,FWorkSheet1,FWorkSheet2: variant;
i:integer;
begin
FMsExcel := CreateOleObject('excel.application');
FWorkBook1:= FMsExcel.WorkBooks.Add;
FWorksheet1:= FWorkBook1.WorkSheets[1];
for i:=1 to 20 do
FWorksheet1.cells[i,1]:=inttostr(i);
FMSExcel.Application.visible := True;
end;
u86210779
一般會員


發表:16
回覆:41
積分:16
註冊:2004-06-08

發送簡訊給我
#2 引用回覆 回覆 發表時間:2007-05-20 14:44:29 IP:218.169.xxx.xxx 訂閱
使用者在等待轉出的時間中可能會去開啟另一個已存在的Excel造成錯誤的解決方式
使用者按按鍵執行後, 出現一個以 showmodel 方式開啟的視窗, 顯示工作進度用.
這樣使用者就沒有機會在開啟其他視窗, 也就沒有機會造成錯誤.
u8821003
一般會員


發表:12
回覆:9
積分:9
註冊:2005-04-02

發送簡訊給我
#3 引用回覆 回覆 發表時間:2008-01-09 17:41:09 IP:61.220.xxx.xxx 訂閱

大大,我也遇到相同的問題耶!
你說用showmodel 方式開啟的視窗,
可是這樣還是可以去開啟另外一個已經存在的excel檔案耶~~
是我不懂你的意思嗎?你可以講清楚一點嗎?

===================引 用 u86210779 文 章===================
使用者在等待轉出的時間中可能會去開啟另一個已存在的Excel造成錯誤的解決方式
使用者按按鍵執行後, 出現一個以 showmodel 方式開啟的視窗, 顯示工作進度用.
這樣使用者就沒有機會在開啟其他視窗, 也就沒有機會造成錯誤.
u86210779
一般會員


發表:16
回覆:41
積分:16
註冊:2004-06-08

發送簡訊給我
#4 引用回覆 回覆 發表時間:2008-01-12 10:45:54 IP:218.175.xxx.xxx 訂閱
試試下列做法
fmHand:=TfmHand.Create(Self);
with fmHand do begin
Caption := '寫入檔案中, 請稍後';
Gauge2.MaxValue := 100;
Gauge2.MinValue := 1;
Gauge2.Progress := 1;
ShowModel; <-- 不是用 show
for i := 1 to 100 do begin
Gauge2.Progress := i;
//寫入 Excel
.
.
.
end;
free;
nil;
end;

===================引 用 文 章===================

大大,我也遇到相同的問題耶!
你說用showmodel 方式開啟的視窗,
可是這樣還是可以去開啟另外一個已經存在的excel檔案耶~~
是我不懂你的意思嗎?你可以講清楚一點嗎?

系統時間:2024-04-30 14:11:10
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!