1

我编写了一个 C# COM(自动化)加载项,我正在使用 Excel 2010 x64 进行测试,在 Windows 7 上运行。它定义了许多用户定义的公式。让我们以一个示例 UDF 为例,它有两个字符串作为参数,首先使用文字调用,然后使用单元格引用:

=MyFunction("A","B")
=MyFunction(A1,B1)

如果区域设置 = 英语,那么这两个都有效。

如果我将区域设置设置为法语并重新打开工作簿,Excel 已将公式更改为:

=MyFunction("A";"B")
=MyFunction(A1;B1)

第一个(带有文字)仍然有效。第二个现在不起作用=它只是返回#VALUE!,甚至没有调用我的托管 UDF 代码(使用 Visual Studio 2010 进行调试)。

为什么是这样?

4

2 回答 2

0

我不知道为什么这种行为会因区域设置而异,但无论如何:

UDF 签名是这样的:

public object MyFunction(string arg1, string arg2)
{

然后我只在代码中使用 arg1 和 arg2。正如我所说,这适用于英语语言环境中的单元格引用。在法语语言环境中,如果我将其重构为如下所示,它就可以工作:

public object MyFunction(object ref1, object ref2)
{
    string arg1 = (ref1 is Range) ? (string)((Range)ref1).Value : (string)ref1;
    string arg2 = (ref2 is Range) ? (string)((Range)ref2).Value : (string)ref2;

这将需要进行大量更改...任何人都知道为什么英语设置允许类型转换在到达 UDF 之前发生?

于 2015-05-01T16:56:30.903 回答
0

您需要明确设置 en-US 文化,以便 UDF 在不同的语言环境中正常工作,例如

System.Threading.Thread.CurrentThread.CurrentCulture = new System.Globalization.CultureInfo("en-US");

加载项开头的某个位置

于 2016-01-15T10:46:13.363 回答