gpt4 book ai didi

c++ - 如何从 XLL UDF 返回数组

转载 作者:太空狗 更新时间:2023-10-29 21:25:16 27 4
gpt4 key购买 nike

我正在尝试使用 C API 为 Excel 编写一个数组构造函数作为工作表函数。

目标:=array_cons(1, 2, 3) => {1, 2, 3}

但是,我没有正确初始化 XLOPER12。在 Excel 中,我的函数当前返回 #NUM。我正在获取参数列表并通过宏将其打包到 vargs 数组中,然后尝试返回提供的数组部分。

#include <windows.h>
#include <xlcall.h>
#include <framewrk.h>
#include <boost/preprocessor.hpp>

#define VARG_COUNT 250
#define VARG_FORMAT(Z, A, B) B##A,
#define VARG_DEF_LIST(N) BOOST_PP_REPEAT(N, VARG_FORMAT, LPXLOPER12 varg) \
LPXLOPER12 varg##N
#define VARG_ARRAY(N) { BOOST_PP_REPEAT(N, VARG_FORMAT, varg) varg##N }
#define GET_VARGS VARG_ARRAY(VARG_COUNT)

__declspec(dllexport) LPXLOPER12 WINAPI array_cons(VARG_DEF_LIST(VARG_COUNT))
{
LPXLOPER12 vargs[] = GET_VARGS;
int args_passed = 0;
for(int i = 0; i < VARG_COUNT; ++i, ++args_passed)
{
if (vargs[i]->xltype == xltypeMissing)
{
break;
}
}
if (args_passed == 0)
{
XLOPER12 err;
err.xltype = xltypeErr;
err.val.err = xlerrValue;
return (LPXLOPER12)&err;
}
XLOPER12 list;
list.xltype = xltypeMulti;
list.val.array.lparray = (XLOPER12*)vargs;
list.val.array.rows = args_passed;
list.val.array.columns = 1;
return (LPXLOPER12)&list;
}

最佳答案

我想通了。这里有几点需要注意 -

您需要确保您的 UDF 注册使用了正确的签名。在我的例子中,我希望 Excel 引用给我它们各自的值,所以我在注册函数时使用了 Q 类型。如果你不明白这一点,请查看http://msdn.microsoft.com/en-us/library/office/bb687869.aspx

为了返回数组,您必须动态分配新内存给 list.val.array.lparray 成员并迭代填充它。

__declspec(dllexport) LPXLOPER12 WINAPI array_cons(VARG_DEF_LIST(VARG_MAX)) {
LPXLOPER12 vargs[] = GET_VARGS;
int args_passed = 0;
for(int i = 0; i < VARG_MAX; ++i, ++args_passed) {
if (vargs[i]->xltype == xltypeMissing) {
break;
}
}
XLOPER12 list;
list.xltype = xltypeMulti | xlbitDLLFree;
list.val.array.lparray = new XLOPER12[args_passed];
list.val.array.rows = args_passed;
list.val.array.columns = 1;
for(int i = 0; i < args_passed; ++i) {
list.val.array.lparray[i] = *vargs[i];
}
return &list;
}

因为我们是动态分配内存,所以我们需要定义回调来释放它。

__declspec(dllexport) void WINAPI xlAutoFree12(LPXLOPER12 p) {
if (p->xltype == (xltypeMulti | xlbitDLLFree)) {
delete [] p->val.array.lparray;
}
}

关于c++ - 如何从 XLL UDF 返回数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14301998/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com