[爆卦]vba字串陣列是什麼?優點缺點精華區懶人包

為什麼這篇vba字串陣列鄉民發文收入到精華區:因為在vba字串陣列這個討論話題中,有許多相關的文章在討論,這篇最有參考價值!作者yuchih0519 (昱)看板Visual_Basic標題Re: [VBA ] Call DL...


最近剛好也在研究怎麼寫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

你可能也想看看

搜尋相關網站