首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >在命令的每一行输出前加上时间戳

在命令的每一行输出前加上时间戳
EN

Unix & Linux用户
提问于 2011-12-13 11:49:12
回答 4查看 210.7K关注 0票数 352

我希望为命令的每一行输出加上时间戳。例如:

代码语言:javascript
复制
foo
bar
baz

会变成

代码语言:javascript
复制
[2011-12-13 12:20:38] foo
[2011-12-13 12:21:32] bar
[2011-12-13 12:22:20] baz

...where时间前缀是打印行的时间。我怎样才能做到这一点?

EN

回答 4

Unix & Linux用户

回答已采纳

发布于 2011-12-14 03:12:08

多用包括ts,它很好地做到了这一点:

command | ts '[%Y-%m-%d %H:%M:%S]'

它也消除了循环的需要,每一行输出都会有一个时间戳。

代码语言:javascript
复制
$ echo -e "foo\nbar\nbaz" | ts '[%Y-%m-%d %H:%M:%S]'
[2011-12-13 22:07:03] foo
[2011-12-13 22:07:03] bar
[2011-12-13 22:07:03] baz

你想知道服务器什么时候重新启动吗?只要运行ping | ts,问题解决了:D。

注意:使用[%Y-%m-%d %H:%M:%.S]实现微秒精度。

票数 519
EN

Unix & Linux用户

发布于 2016-07-27 10:45:44

对于逐行增量度量,请尝试格尼蒙

它是一个命令行实用工具,有点像更多的ts,可以将时间戳信息添加到另一个命令的标准输出中。对于长时间运行的过程很有用,在这里,您想要一个历史记录,说明什么花费了这么长的时间。将任何东西连接到gnomon,都会在每一行上加上一个时间戳,表示这一行是缓冲区中最后一行的长度--也就是说,下一行出现所用的时间。默认情况下,gnomon将显示每行之间经过的秒数,但这是可配置的。

票数 70
EN

Unix & Linux用户

发布于 2020-06-16 16:50:42

为了解决这个问题,我刚刚写了一封厚颜无耻的文章:ets,用Go写的。

您可以在项目页面上找到许多使用示例。

与现有的答案和类似的提供不同之处在于,ets被设计为在pty (伪tty)中为您运行命令,也就是说,模拟在tty中本地运行的命令。与管道命令输出到例如ts相比,这使得时间戳几乎是透明的,并解决了大量管道问题:

  • 一些程序在写入管道时会积极地缓冲,这样您就看不到输出,然后看到大量的输出(是的,您可以将stdbuf和ts封装在别名/函数中,但是如果事情不成定局的话,不是更好吗?)
  • 一些程序在写入管道时禁用颜色和/或交互性;
  • 退出状态已经消失,除非您打开管道故障;等等。

命令可以直接执行,这意味着您可以简单地将ets添加到现有命令行中,或者它们可以是shell命令(如上面的gif所示)。当然,如果您想输入输出,ets也可以这样做。

ets支持与ts相同的时间戳模式:绝对时间模式、经过时间模式和增量时间模式。它使用更清晰的缺省值(例如,单调时钟总是用于经过/增量时间戳),并且对自定义时区有额外的支持。有一个详细的比较这里

再说一遍,https://github.com/zmwangx/ets。让它转一转,报告错误等。

票数 9
EN
页面原文内容由Unix & Linux提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://unix.stackexchange.com/questions/26728

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档