全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:3316
推到 Plurk!
推到 Facebook!

關於 could not convert variant of type (dispatch) into type (string)??

答題得分者是:pceyes
l730626
一般會員


發表:22
回覆:21
積分:8
註冊:2009-03-29

發送簡訊給我
#1 引用回覆 回覆 發表時間:2009-09-30 23:28:08 IP:118.232.xxx.xxx 訂閱
如題
我用delphi去讀excel~
然後判定如果該excel裡有某關鍵字時就列出該檔名與表格名
可以執行程式時~都會出現
could not convert variant of type (dispatch) into type (string)
然後就會中斷程式~程式停在以下這一行~
IF (STRING((MsExcel.Cells[I,j]))=edit2.Text) THEN

請問各位先進~我有哪邊語法是錯誤的?~還是我應該怎麼修改??
老大仔
尊榮會員


發表:78
回覆:837
積分:1088
註冊:2006-07-06

發送簡訊給我
#2 引用回覆 回覆 發表時間:2009-10-01 08:18:06 IP:59.120.xxx.xxx 未訂閱
照這樣看來應該是型態錯了...吧!?
你的cell跟edit2的資料型態應該是不同的
把string拿掉試試看~

供參考~
st33chen
尊榮會員


發表:15
回覆:591
積分:1201
註冊:2005-09-30

發送簡訊給我
#3 引用回覆 回覆 發表時間:2009-10-01 09:50:39 IP:61.219.xxx.xxx 未訂閱
您好,

老大仔大大說得沒錯, 是 datatype 不對.

發生問題的那個 cell 是 dispatch 型, 也就是 指向一個 automation 物件的 pointer.
我想最直接(兵來將擋)的方法是
先用 varType function 去判斷是否是 dispatch 型, 如果不是再用 string 去轉型和 edit2.text 去比較

if varType(MsExcel.Cells[I,j]) <> varDispatch then begin

// 您原來的程式段
IF (STRING((MsExcel.Cells[I,j]))=edit2.Text) THEN ....

end;

參考一下,
ps. 我沒實測哦, 請自行測一下


又, 另一方法是用 try ... except ... end 結構去排除不能轉的,
不過可能不是好方法, 因有可能包容其他錯誤.

------
IS IT WHAT IT IS
我是 李慕白 請倒著唸.
又想把老話拿出來說, 請用台語發音 : 專家專家全是ROBOT CAR (滷肉腳啦);
都已接手這麼久了, 績效還是那麼爛, 講話還那麼大聲.
編輯記錄
st33chen 重新編輯於 2009-10-01 09:55:59, 註解 無‧
st33chen 重新編輯於 2009-10-01 09:57:51, 註解 無‧
pceyes
尊榮會員


發表:70
回覆:657
積分:1140
註冊:2003-03-13

發送簡訊給我
#4 引用回覆 回覆 發表時間:2009-10-05 22:52:49 IP:220.141.xxx.xxx 訂閱
IF  (vartostr((MsExcel.Cells[I,j]))=edit2.Text)  THEN
------
努力會更接近成功
max5020
資深會員


發表:29
回覆:277
積分:321
註冊:2003-06-04

發送簡訊給我
#5 引用回覆 回覆 發表時間:2009-10-29 10:13:40 IP:59.120.xxx.xxx 訂閱

===================引 用 l730626 文 章===================
如題
我用delphi去讀excel~
然後判定如果該excel裡有某關鍵字時就列出該檔名與表格名
可以執行程式時~都會出現
could not convert variant of type (dispatch) into type (string)
然後就會中斷程式~程式停在以下這一行~
IF (STRING((MsExcel.Cells[I,j]))=edit2.Text) THEN


請問各位先進~我有哪邊語法是錯誤的?~還是我應該怎麼修改??
pceyes
尊榮會員


發表:70
回覆:657
積分:1140
註冊:2003-03-13

發送簡訊給我
#6 引用回覆 回覆 發表時間:2009-10-29 11:10:36 IP:124.199.xxx.xxx 訂閱
var
vStr : OleVariant;
begin
vStr :=edit2.text;
IF MsExcel.Cells[I,j]=edit2.Text THEN
:
:
------
努力會更接近成功
老大仔
尊榮會員


發表:78
回覆:837
積分:1088
註冊:2006-07-06

發送簡訊給我
#7 引用回覆 回覆 發表時間:2009-10-29 11:17:11 IP:59.120.xxx.xxx 未訂閱
pceyes大大
是不是應該寫成:
vStr :=edit2.text;
IF MsExcel.Cells[I,j]=vStr THEN
系統時間:2024-04-26 0:39:34
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!