首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >dmesg:自定义时间格式

dmesg:自定义时间格式
EN

Unix & Linux用户
提问于 2019-08-31 05:45:25
回答 2查看 1.3K关注 0票数 5

dmesg有打印人类可读时间戳的选项-T,新版本有选项--time-format,可以更改时间格式,例如:

代码语言:javascript
复制
--time-format iso

不幸的是,iso时间格式的可读性也不高。我可以使用标准的date语法定义自己的时间格式吗?ie:

代码语言:javascript
复制
date +%F-%T
EN

回答 2

Unix & Linux用户

回答已采纳

发布于 2019-09-02 18:04:13

是的,您可以这样做,例如,用gawk (GNU awk)重新格式化时间:

代码语言:javascript
复制
dmesg --time-format iso | gawk '{ printf (strftime("+%F-%T",mktime(gensub("[-+T:,]"," ","g",$1)))) ; $1 = ""; print $0}'

dmesg在这里打印iso日期如下:

代码语言:javascript
复制
2019-09-02T06:10:30,708864+02:00 this is an important message

我们去掉第一个特殊字符字符串,然后在(g)awk中使用D7函数将字符串解析为日期,然后使用strftime格式化--使用您最喜欢的参数。

这给出了如下的东西

代码语言:javascript
复制
+2019-09-02-06:10:30 this is an important message

Small注释:

  • 我们在这里忽略时区,假设这是显而易见的,因为我们在本地运行该命令。
  • 请注意,如果由于时间戳的存储方式,dmesg给出的时间可能是不准确的(事实上,有时是很遥远的),如果您挂起并唤醒计算机,请参阅dmesg(1):man1dmesg
票数 2
EN

Unix & Linux用户

发布于 2019-09-02 18:15:55

不能,但可以解析dmesg-output:

代码语言:javascript
复制
dmesg --time-format iso \
| while read datestring rest; do \
  printf '%s\n' "$(date -d "$datestring" +%F-%T) $rest"; done
票数 3
EN
页面原文内容由Unix & Linux提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

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

复制
相关文章

相似问题

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