Re: [VBA ] Call DLL 回傳一個陣列給VBA

看板Visual_Basic作者 (昱)時間14年前 (2009/09/20 03:10), 編輯推噓0(000)
留言0則, 0人參與, 最新討論串2/2 (看更多)
最近剛好也在研究怎麼寫DLL讓Excel VBA呼叫(不過我是用Delphi 7) 我的心得是,使用標準DLL的傳入參數與回傳值儘量採用簡單的標準資料型態, 所謂"標準",是指integer, single, double, boolean....等有公眾定義格式的型態, 可以避免某個語言專用格式(像是Delphi的String)不被其他語言所認識而造成錯誤。 所謂"簡單",是指"單值"而非陣列,可以讓參數及回傳值直接使用, (陣列不是不能用,只是要以指針定址方式自己去搬移記憶體,需要前處理與後處理) 我不懂C,不過看您的C++函數宣告猜想,似乎回傳值是個double單值?(那這就不多說了) 我對於陣列參數的傳入傳出也是在摸索中,所以無法告訴你怎麼直接傳陣列進去, 不過我自己是想到一個堪用的替代方案:字串 比如說,我要傳一個如下的二維陣列 1 23 456 7 89 10 11 12 13 我先將他改寫成單一字串(行、列分隔符號可自訂,我個人習慣用MATLAB風格...) 1,23,456;7,89,10;11,12,13 將此字串當作傳入參數,然後到DLL裡面寫個解譯函式Split_String_to_Array, 您的test1函式只需要一開始先呼叫Split_String_to_Array將字串還原成陣列, 就可以繼續進行原有的計算了。 不過由於是字串,什麼亂七八糟的內容都不分辨,因此要特別注意字串用分隔符號拆開後 每個元素的資料型態是否正確,不然會有錯誤產生。 不好意思,只是一個門外漢,所以只有這種不三不四的旁門左道,獻醜了! 有這類問題的應該不只我們兩個人,還希望真正的高手能出面指導一下正統的作法, 讓後進們可以向前輩學習學習,謝謝。 ※ 引述《a5170040 (Piggy)》之銘言: : 想請問現在我在C++上面製作好DLL : 想要在VBA上面使用 : 我的函數是這樣的 : double test1(double data[][2],int c,double s[3],double o[3],summary[7]) : 其中summary[7]一開始是一個空白陣列 : 由VBA先給初值 : 然後VBA呼叫完DLL之後回傳已經更新的summary[7] : 想請問這一段要怎麼宣告跟使用 : 爬文有發現傳一維陣列好像是這樣 : 是這樣宣告嗎 : test1(ByRef data As variant,ByVal c,ByRef s() As double, _ : ByRef o(),ByRef summary() As double) : 使用的時候傳進去 : summary = test1(data,c,s,o,summary) : 不過我怎麼改好像都不對 : 可以麻煩指點迷津一下嗎?謝謝 : 謝謝! -- ※ 發信站: 批踢踢實業坊(ptt.cc) ◆ From: 114.42.133.147
文章代碼(AID): #1AjIopXw (Visual_Basic)
文章代碼(AID): #1AjIopXw (Visual_Basic)