Windows PowerShellブログでこの役立つ記事を読んだ後、配列の最初の部分を「シフト」できることに気付きましたが、PowerShellで要素を「シフト解除」または配列の前面にプッシュする方法がわかりませんでした。
最後に読み取った項目を最初に配列にプッシュして、ハッシュオブジェクトの配列を作成しています。これを達成するためのより良い方法があるかどうか疑問に思います。
## Create a list of files for this collection, pushing item on top of all other items
if ($csvfiles[$collname]) {
$csvfiles[$collname] = @{ repdate = $date; fileobj = $csv }, $csvfiles[$collname] | %{$_}
}
else {
$csvfiles[$collname] = @{ repdate = $date; fileobj = $csv }
}
注意すべき点がいくつかあります。
- 配列を参照するだけでネストされた配列構造が作成されるため、foreachループ%{$_}を使用して前の配列要素を展開する必要があります。すべての要素を同じレベルにする必要があります。
- 空の配列と要素を含む配列を区別する必要があります。空の配列を展開しようとすると、配列の最後に$null要素が配置されます。
考え?
PS:空のハッシュ要素がNULL値を生成する理由は、PowerShellでは$nullがスカラーとして扱われるためです。詳細については、https://connect.microsoft.com/PowerShell/feedback/details/281908/foreach-should-not-execute-the-loop-body-for-a-scalar-value-of-nullを参照してください。
答え:
最善の解決策は、$ nullの問題を回避するコードではなく、必要に応じて空の配列を事前に作成することです。これは、.NETArrayListとネイティブPoSh配列を使用した書き直しです。
if (!$csvfiles.ContainsKey($collname)) {
$csvfiles[$collname] = [System.Collections.ArrayList]@()
}
$csvfiles[$collname].insert(0, @{ repdate = $repdate; fileobj = $csv })
## NATIVE POSH SOLUTION...
if (!$csvfiles.ContainsKey($collname)) {
$csvfiles[$collname] = @()
}
$csvfiles[$collname] = @{ repdate = $repdate; fileobj = $csv }, `
$csvfiles[$collname] | %{$_}