在 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
}
我应该编写一个脚本来从特定文件中按字母顺序对单词进行排序,并将它们放入名为 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
}