用Powershell从文件中删除最后一行

11 浏览
0 Comments

用Powershell从文件中删除最后一行

我正在使用gc FileWithEmptyLines.txt | where {$_ -ne ""} > FileWithNoEmptyLines.txt来删除SSRS在我的CSV文件底部添加的空行。

然而,最后一行上有数据,它以CRLF结尾(在Notepad++中查看)- 这并没有被删除,所以从技术上讲文件底部仍然有一个空行。

有没有办法删除最后一行的CRLF(当然保持数据完整)?

0
0 Comments

问题的原因是在于需要使用PowerShell删除文本文件的最后一行,但是上述的示例和解决方案并没有起作用。解决方法是使用下面的命令:

$file = "file.txt"
Get-Content $file | Measure-Object -Line
$a = (Get-Content $file | Measure-Object)
(Get-Content $file) | ? {($a.count-1)-notcontains $_.ReadCount} | Set-Content $file

如果你正在处理一个大文件,你可能需要先将其导入到一个临时文件中。

这个命令似乎是删除倒数第二行。将{($a.count-1)改为{($a.count-0)}可以删除最后一行。根据需要调整该数字以从底部删除特定行数。请记住,在这种情况下,第一行(底部行)的编号是0。

0
0 Comments

在使用Get-Content读取文件时,它将每一行作为字符串流传递给管道。当Out-File(实际上>的别名)接收这些字符串时,它总是附加一个行终止符序列。如果文件不太大,可以尝试以下方法解决该问题:

$text = [IO.File]::ReadAllText("c:\FileWithEmptyLinesAtEnd.txt")
[IO.File]::WriteAllText("c:\FileWithEmptyLinesAtEnd.txt", $text.TrimEnd())

这是修改前的文件内容:

14> fhex .\FileWithEmptyLinesAtEnd.txt
Address:  0  1  2  3  4  5  6  7  8  9  A  B  C  D  E  F ASCII
-------- ----------------------------------------------- ----------------
00000000 73 65 72 76 65 72 31 2C 73 65 72 76 65 72 32 2E server1,server2.
00000010 64 6F 6D 61 69 6E 2E 6C 6F 63 61 6C 2C 73 65 72 domain.local,ser
00000020 76 65 72 33 0D 0A 20 20 20 20 20 20             ver3..

修改后的文件内容:

19> fhex .\FileWithEmptyLinesAtEnd.txt
Address:  0  1  2  3  4  5  6  7  8  9  A  B  C  D  E  F ASCII
-------- ----------------------------------------------- ----------------
00000000 73 65 72 76 65 72 31 2C 73 65 72 76 65 72 32 2E server1,server2.
00000010 64 6F 6D 61 69 6E 2E 6C 6F 63 61 6C 2C 73 65 72 domain.local,ser
00000020 76 65 72 33                                     ver3

这似乎没有做任何事情?文件没有被修改。

0
0 Comments

问题原因:在使用PowerShell对文件进行操作时,需要移除文件的最后一行。然而,使用给出的解决方法时,可能会遇到一些错误,比如参数错误或只移除了一部分字符而不是整个最后一行。

解决方法:为了从文件中移除最后一行,可以使用以下代码:

$content = Get-Content -Path 'foo.txt'
$content = $content[0..($content.Count-2)]
$content | Set-Content -Path 'foo.txt'

这段代码首先使用Get-Content命令获取文件的内容,并将其存储在变量$content中。然后,使用数组切片操作([0..($content.Count-2)])将$content中除最后一行之外的所有行提取出来。最后,使用Set-Content命令将修改后的内容写回到文件中。

这个解决方法避免了直接操作文件流,而是将文件的内容读取到内存中进行操作,因此适用于处理较小的文件。如果需要处理非常大的文件,可能需要使用其他方法来避免将整个文件读取到内存中。

需要注意的是,这个解决方法假设文件的编码是ASCII、Latin-*或UTF-8。如果文件的编码是UTF-16,可能需要对代码进行适当的修改。

总结起来,通过将文件的内容读取到内存中进行操作,可以使用PowerShell移除文件的最后一行。这种方法适用于处理较小的文件,可以避免将整个文件读取到内存中。如果需要处理非常大的文件,可能需要使用其他方法来避免内存溢出的问题。

0