当我尝试传递一维数组时,这工作正常
__declspec(dllexport) LPXLOPER TestArray()
{
XLOPER xlValues[2];
xlValues[0].xltype = xltypeNum;
xlValues[1].xltype = xltypeNum;
xlValues[0].val.num = 123;
xlValues[1].val.num = 345;
static XLOPER xlArray;
xlArray.xltype = xltypeMulti | xlbitDLLFree;
xlArray.val.array.rows = 2;
xlArray.val.array.columns = 1;
xlArray.val.array.lparray = &xlValues[0];
return (LPXLOPER)&xlArray;
}
但是当我尝试传递一个多维数组时,该函数返回#NUM!
__declspec(dllexport) LPXLOPER TestArray1()
{
XLOPER xlValues[2][2];
xlValues[0][0].xltype = xltypeNum;
xlValues[0][1].xltype = xltypeNum;
xlValues[1][0].xltype = xltypeNum;
xlValues[1][1].xltype = xltypeNum;
xlValues[0][0].val.num = 123;
xlValues[0][1].val.num = 456;
xlValues[1][0].val.num = 345;
xlValues[1][1].val.num = 43456;
static XLOPER xlArray;
xlArray.xltype = xltypeMulti | xlbitDLLFree;
xlArray.val.array.rows = 2;
xlArray.val.array.columns = 2;
xlArray.val.array.lparray = &xlValues[0][0];
return (LPXLOPER)&xlArray;
}
有什么想法吗?提前致谢!!
最佳答案
在 TestArray( ) 和 TestArray1( ) 中,xlValues 是堆栈上的局部变量,因此当函数返回时它将被运行时释放。您需要使 xlValues 堆分配内存才能可靠地工作。 XLL 开发是一种黑暗艺术。如果你想认真对待它,你应该买一本 Steve Dalton 的书。
关于c++ - 从 C++ xll 返回多维数组到 excel,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30533839/