在列上的表达式上的对象会收到错误哈希字面不完整



为什么我能够在脚本块之外执行命令,而不是在其中?

我的最终目标是根据预定义的类别对目录列表进行排序。该代码从目录列表中创建一个动态对象,并添加两个列。创建的第一列是从名称派生的类别,基于第一个的第二列是用于以后排序的索引。


实际错误

The hash literal was incomplete.
At line:0 char:0

独立工作代码

$importance = "Hierarchy", "Item", "UPC", "Color", "Price"
$importance.IndexOf('UPC') # returns 2

故障代码

总体任务是进行目录列表,最终$importance对列表进行排序。通过创建动态列,它将在名为Index的新列上对其进行排序(未显示(。

$match = "UPC|Item|Color|Price|Hierarchy"
gci $incrementalTargetDir `
| Select-Object Name, @{label="Category"; Expression= {[regex]::match($_.BaseName, $match).Groups[0].Value}} `
| Select-Object Name, @{label="Index"; Expression= { $importance.IndexOf($_.Category) } 

在第二个Select-Object

上失败

首先选择成功返回此数据:

Name                        Category
----                        --------
ColorStyleSize.txt          Color
Item.txt                    Item
FieldProductHierarchy.txt   Hierarchy
UPC.txt                     UPC
PriceAdjust.txt             Price

还尝试添加以相同结果添加范围script:

 …. Expression= { $script:importance.IndexOf($_.Category)

我能够通过将此代码作为脚本运行来复制问题。第二个Select-Object中的哈希表的丢失关闭}丢弃了此错误。一旦添加了丢失的},我就可以在没有问题的情况下运行代码。

另一种方法是使用foreach循环和自定义对象输出。如果您不想排除不匹配的项目,则可以删除if语句。

$incrementalTargetDir = 'Drive:Folder1Folder2'
$importance = "Hierarchy", "Item", "UPC", "Color", "Price"
$match = "UPC|Item|Color|Price|Hierarchy"
foreach ($file in (Get-ChildItem $incrementalTargetDir)) {
    $Category = $null
    $Category = [regex]::match($file.BaseName, $match).Groups[0].Value
    if ($Category) {
        [pscustomobject]@{
            Name = $file.Name
            Category = $Category
            Index = $importance.IndexOf($Category)
        }
    }
}

相关内容

  • 没有找到相关文章

最新更新