1

我从 Excel 的Cells.Find()方法中得到了一些奇怪的行为:

我正在搜索的变量:

PS > $volumename
vol_01       

PS > $volumename.GetType()

IsPublic IsSerial Name                                     BaseType                                                                                                                                            
-------- -------- ----                                     --------                                                                                                                                            
True     True     String                                   System.Object 

不产生任何结果:

PS > $sheet.Cells.Find($volumename).Row

但是如果我手动复制并粘贴该变量的值:

PS > $volumename = "vol_01"
PS > $volumename.GetType()

IsPublic IsSerial Name                                     BaseType                                                                                                                                            
-------- -------- ----                                     --------                                                                                                                                            
True     True     String                                   System.Object 

得到我期望的值:

PS > $sheet.Cells.Find($volumename).Row
198

在我看来,它们在各方面都完全一样。并非所有情况都会发生这种情况。一些卷名可以很好地通过,而另一些则不能。我确实清理了这篇文章的卷名,因为它有一个客户命名约定。它与上面的格式相同,并且与有效的卷名格式相同。

4

1 回答 1

2

以下代码段可用于检查字符串中隐藏的控制字符

PS> & { [int[]] [char[]] $Args[0] | % { '0x{0:x} [{1}]' -f $_, [char] $_ } } "vol_01`n"
0x76 [v]
0x6f [o]
0x6c [l]
0x5f [_]
0x30 [0]
0x31 [1]
0xa [
]

第一列是每个字符的 Unicode 代码点(“ASCII 码”),第二列是字符本身,包含在[...]

请注意,我"`n"在字符串的末尾添加了一个换行符 ( U+000A) - 其代码点表示为十六进制。数是0xa

如果在您的情况下,字符串中唯一不需要的部分是尾随空格,您可以按如下方式删除它们:

$volumename.TrimEnd() # trim trailing whitespace

在您的情况下,尾随空格是0xa0NO -BREAK SPACE ( U+00A0) ,正如Tom Blodget指出的那样,它.TrimEnd()也会被删除。


基于上述的简单函数包装器,用于管道输入:

filter debug-Chars { [int[]] [char[]] $_ | % { '0x{0:x} [{1}]' -f $_, [char] $_ } }

样品用途:

"vol_01`n" | debug-Chars
于 2018-10-04T14:00:58.613 回答