我有一个从 InstallShield 执行的 .NET 自定义操作 (DTF)。
在 .NET CA 中,我正在提取一个值为 “[CommonAppDataFolder]abc\def.txt”
的 MSI 属性。
该属性的访问方式如下:
string val = session["MY_PROPERTY"]; // Microsoft.Deployment.WindowsInstaller.Session
当我将此变量打印到日志文件时,我得到:C:\ProgramData\abc\def.txt
。这正是我所期望的。
但是,当我使用 []
运算符逐个字符查看时,我从未替换的值中获取字符:
[CommonAppDataFolder]...
例如,val[0]
是 '['
而不是 'C'
.
这怎么可能?
此外,==
、string.compare()
、!=
等都没有给出预期的结果(我'想象一下它们在底层使用了 []
运算符)。
编辑:
这就是我的记录方式:
session.Log("文件名:{0}", val);
这就是我逐个字符打印的方式:
for (int i = 0; i < val.Length; i++)
{
session.Log(val[i].ToString());
}
最佳答案
字符串 val 仍然包含未替换的版本,因此 for 循环工作正常。
session 中的 Log() 方法使用“val”作为格式字符串(而不是文字),它在写入结果之前用实际值替换任何占位符。
如果您下载调试符号(输出可能不合法发布在此处),您可以看到这种情况发生。
简而言之,Log() 调用 Message(),而 Message() 又调用 MsiProcessMessage()在该 msdn 页面中,它引用 MsiFormatRecord() 。在该文件的末尾,它解释了自动发生的替换。对于本例来说,最值得注意的是:
- If a substring of the form [propertyname] is encountered, it is replaced by the value of the property.
- If a substring of the form [%environmentvariable] is found, the value of the environment variable is substituted.
尝试以下代码以获得预期结果
string formattedVal = session.Format(val)
for (int i = 0; i < formattedVal.Length; i++)
{
session.Log(formattedVal[i].ToString());
}
关于.NET String [] 运算符返回与 ToString() 不同的内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12983129/