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

偵測有無安裝Excel

答題得分者是:taishyang
maplefog
一般會員


發表:16
回覆:24
積分:13
註冊:2008-11-08

發送簡訊給我
#1 引用回覆 回覆 發表時間:2009-10-03 17:29:27 IP:140.118.xxx.xxx 訂閱

程式中有需要用到把資料輸出到Excel的功能

使用
Excel=CreateOleObject("Excel.Application");
Excel.OlePropertySet("Visible", true);

但是如果使用者沒有安裝Excel時,會顯示:無效的類別字串: ProgID: "Excel.Application"

請問怎麼先判斷有沒有安裝Excel? 謝謝各位

TWY
高階會員


發表:0
回覆:132
積分:151
註冊:2009-09-02

發送簡訊給我
#2 引用回覆 回覆 發表時間:2009-10-04 22:25:45 IP:220.132.xxx.xxx 訂閱
我看過有人是這樣做的(如下Code),更仔細點你可以進一步比對錯誤訊息
我相信有更制式的寫法,但利用 try-except-end 應該是最簡單吧
try
Excel=CreateOleObject("Excel.Application");
Excel.OlePropertySet("Visible", true);

except
on E:Exception do
ShowMessage('沒有安裝 Excel');
end;


編輯記錄
TWY 重新編輯於 2009-10-04 22:27:39, 註解 無‧
TWY 重新編輯於 2009-10-04 22:28:23, 註解 無‧
syntax
尊榮會員


發表:26
回覆:1139
積分:1258
註冊:2002-04-23

發送簡訊給我
#3 引用回覆 回覆 發表時間:2009-10-05 13:09:12 IP:59.125.xxx.xxx 訂閱

可以透過判斷 product codes and component IDs 來達成,見單的說就是讀 registry,看有沒有安裝 excel 後會出現的機碼

例如
Microsoft Office Excel 工作表
{00020830-0000-0000-C000-000000000046}

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

程式中有需要用到把資料輸出到Excel的功能

使用
Excel=CreateOleObject("Excel.Application");
Excel.OlePropertySet("Visible", true);

但是如果使用者沒有安裝Excel時,會顯示:無效的類別字串: ProgID: "Excel.Application"

請問怎麼先判斷有沒有安裝Excel? 謝謝各位

編輯記錄
syntax 重新編輯於 2009-10-05 13:12:41, 註解 無‧
taishyang
站務副站長


發表:377
回覆:5485
積分:4552
註冊:2002-10-08

發送簡訊給我
#4 引用回覆 回覆 發表時間:2009-10-05 14:36:16 IP:122.116.xxx.xxx 訂閱
插花一下:
http://delphi.ktop.com.tw/board.php?cid=30&fid=72&tid=39232
裡面的連結有範例,可由GetPath得知 ^^
RootKit
資深會員


發表:16
回覆:357
積分:419
註冊:2008-01-02

發送簡訊給我
#5 引用回覆 回覆 發表時間:2009-10-05 20:48:42 IP:122.126.xxx.xxx 訂閱
檢查 OleObject 是否存在。

[code delphi]
var
ClsID: TCLSID;
begin
if CLSIDFromProgID('Excel.Application',ClsID)=S_OK then
begin
Showmessage('Ms Excel is installed.');
end else begin
// 沒有安裝 EXCEL
end;

end;

[/code]

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