在 Powershell 中使用 Range 运算符生成按字母顺序命名的文本文件

Using Range operator to generate text files named with alphabetical order in Powershell

我应该编写一个脚本来从特定文件中按字母顺序对单词进行排序,并将它们放入名为 A.txt、B.txt 等的 26 个文本文件中,依此类推,直到 Z.txt。

我能够在 Powershell 中实现以下代码,输出以数字命名的文本文件:

$Content = Get-Content ".\sample.txt"
$Content = ($Content.Split(" .,:;?!/()[]{}-```"")|sort)
$linecount = 0
$filenumber = 0
$destPath = "C:\"
$destFileSize = 26

$Content | % {
    Add-Content $destPath$filenumber.txt "$_"
    $linecount++
    If ($linecount -eq $destFileSize) {
        $filenumber++         
        $linecount = 0
    }
}

如何更改代码以显示按字母顺序命名的输出文本文件

使用Group-Object根据第一个字母对单词进行分组:

$Content |Group {$_.Substring(0,1).ToUpper()} |ForEach-Object {
  $path = Join-Path $destPath $_.Name
  $_.Group |Set-Content $path
}