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

问题描述

我应该编写一个脚本,将特定文件中的单词按字母顺序排序,并将它们放入名为 A.txt、B.txt 等直至 Z.txt 的 26 个文本文件中。

我能够在 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
}