Мы переносим код VB6, который использует функции Excel VBA для некоторых операций, на C# .NET. У меня нет большого опыта работы с VBA, VB6 или Interops.
Я могу вызвать функцию VBA, имеющую строковый параметр, из C#, и мне удалось присвоить строку ячейке Excel как хорошо. Классическая программа «Hello World». Это было захватывающе.
Затем я написал пример функции VBA с параметром Collection, потому что именно он есть в исходном файле .xlsm/.xlt. В консольном приложении я попытался передать аргумент HashTable (это наиболее близко к тому, что нам нужно) в функцию VBA с параметром Collection. Я получаю исключение System.Runtime.InteropServices.COMException: 'Несоответствие типов. (Исключение из HRESULT: 0x80020005 (DISP_E_TYPEMISMATCH))'.
Я также пытался использовать Microsoft.VisualBasic.Collection и пытался преобразовать HashTable в тип данных коллекции. и я все еще получаю вышеуказанную ошибку.
(Мы не можем изменить существующую функцию VBA)
Есть ли способ передать словарь или любую другую коллекции C# в параметр коллекции функции Excel VBA?
Подробнее здесь: https://stackoverflow.com/questions/787 ... -parameter
Передача аргумента HashTable в функцию Excel VBA с параметром Collection ⇐ C#
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение
-
-
Chromadb: Почему результаты Collection.query() и Collection.get() различаются?
Anonymous » » в форуме Python - 0 Ответы
- 34 Просмотры
-
Последнее сообщение Anonymous
-
-
-
Chromadb: Почему результаты Collection.query() и Collection.get() различаются?
Anonymous » » в форуме Python - 0 Ответы
- 23 Просмотры
-
Последнее сообщение Anonymous
-