我正在使用 PowerShell 3。
连接文件的最佳做法是什么?
file1.txt + file2.txt = file3.txt
PowerShell 是否提供了直接执行此操作的工具?还是我需要将每个文件的内容加载到局部变量中?
我正在使用 PowerShell 3。
连接文件的最佳做法是什么?
file1.txt + file2.txt = file3.txt
PowerShell 是否提供了直接执行此操作的工具?还是我需要将每个文件的内容加载到局部变量中?
如果所有文件都存在于同一目录中并且可以通过简单的模式匹配,则以下代码会将所有文件合并为一个。
Get-Content .\File?.txt | Out-File .\Combined.txt
I would go this route:
Get-Content file1.txt, file2.txt | Set-Content file3.txt
Use the -Encoding parameter on Set-Content if you need something other than ASCII which is the default for Set-Content.
如果你需要更多的灵活性,你可以使用类似的东西
Get-ChildItem -Recurse *.cs | ForEach-Object { Get-Content $_ } | Out-File -Path .\all.txt
警告:使用简单的连接Get-Content
(无论是否使用-Raw
标志)适用于文本文件;Powershell 对此非常有帮助:
-Raw
,它会“修复”(即中断,双关语)换行符,或者 Powershell 认为的换行符。-Raw
,您会在每个文件部分的末尾获得一个终止行结尾(通常为 CR+LF),该结尾添加在管道的末尾。在较新的 Powershell 的 Set-Content 中有一个选项。要连接二进制文件(即,由于某种原因被拆分并需要再次放在一起的任意文件),请使用以下任一方法:
Get-Content -Raw file1, file2 | Set-Content -NoNewline destination
或类似的东西:
Get-Content file1 -Encoding Byte -Raw | Set-Content destination -Encoding Byte
Get-Content file2 -Encoding Byte -Raw | Add-Content destination -Encoding Byte
另一种方法是使用 CMD shell 并使用
copy file1 /b + file2 /b + file3 /b + ... destinationfile
您不得覆盖任何部分,即使用任何部分作为目标。目标文件必须不同于任何部分。否则你会大吃一惊,必须找到文件部分的备份副本。
如果您想确保以特定顺序完成连接,请使用Sort-Object -Property <Some Name>
参数。例如,根据升序排列的名称进行连接:
Get-ChildItem -Path ./* -Include *.txt -Exclude output.txt | Sort-Object -Property Name | ForEach-Object { Get-Content $_ } | Out-File output.txt
重要提示: -Exclude
并且Out-File
必须包含相同的值,否则,它将递归地继续添加,output.txt
直到您的磁盘已满。
请注意,您必须*
在参数末尾附加 a ,-Path
因为您正在使用-Include
,如Get-ChildItem文档中所述。
基于@Keith 答案的概括:
gc <some regex expression> | sc output
gc file1.txt, file2.txt > output.txt
我认为这是尽可能短的。
这是一个有趣的示例,说明如何基于 Powershell 7 制作 zip-in-image 文件
Get-Content -AsByteStream file1.png, file2.7z | Set-Content -AsByteStream file3.png
Get-Content -AsByteStream file1.png, file2.7z | Add-Content -AsByteStream file3.png