shell:删除巨大文本日志文件的最后一行

时间:2012-08-29 11:04:41

标签: shell tail

我问过question关于在PHP中弹出文本文件的最后一行,现在,是否可以在shell脚本中重写逻辑?

我试过这个以获得最后一行:

tail -n 1 my_log_file.log

但我不知道如何删除最后一行并保存文件。

P.S。鉴于我使用的是Ubuntu服务器。

4 个答案:

答案 0 :(得分:31)

要获取没有最后一行的文件内容,可以使用

head -n-1 logfile.log

(我不确定这是否得到支持)

sed '$d' logfile.log

答案 1 :(得分:19)

你想要的是在最后一行之前截断文件而不必完全读取文件。

truncate -s -"$(tail -n1 file | wc -c)" file

假设当前没有写入文件。

truncate是GNU coreutils的一部分(通常在最新的Linux发行版中找到),并不是标准化的Unix或POSIX命令。许多“dd”实现也可用于截断文件。

答案 2 :(得分:11)

(解决方案基于sch's answer因此应归功于他/她)

此方法将允许您有效地检索文件的最后一行并截断文件以删除该行。这可以更好地处理大输入,因为文件不是按顺序读取的。

# retrieve last line from file
LAST=$(tail -n 1 my_log_file.log)

# truncate file
let TRUNCATE_SIZE="${#LAST} + 1"
truncate -s -"$TRUNCATE_SIZE" my_log_file.log

# ... $LAST contains 'popped' last line

请注意,如果在调用tailtruncate之间修改了文件,则无法正常工作。

答案 3 :(得分:4)

一种方法是:

sed '$d' < f1 > f2 ; mv f2 f1