ping加时间戳

Linux:

# 日期在后面

ping www.baidu.com | awk ‘{print $0″\t” strftime(“%F_%H:%M:%S”,systime());fflush()}’

结果写入日志:nohup pingwww.baidu.com| awk ‘{print $0″\t” strftime(“%F_%H:%M:%S”,systime());fflush()}’ >>ping_result.log 2>&1 &

# 日期在前面

ping www.baidu.com | awk ‘{print strftime(“%F_%H:%M:%S”,systime())”\t” $0;fflush()}’

结果写入日志:nohup pingwww.baidu.com| awk ‘{print strftime(“%F_%H:%M:%S”,systime())”\t” $0;fflush()}’ >>ping_result.log 2>&1 &

Windows:

打开 powershell,运行下面的命令:

ping www.baidu.com -t | Foreach{“{0} – {1}” -f (Get-Date),$_}

结果写入日志:ping www.baidu.com -t | Foreach{“{0} – {1}” -f (Get-Date),$_} >>d:\ping_baidu.logstrftime补充:函数strftime()的操作有些类似于sprintf():识别以百分号(%)开始的格式命令集合,格式化输出结果放在一个字符串中。格式化命令说明串strDest中各种日期和时间信息的确切表示方法。格式串中的其他字符原样放进串中。格式命令列在下面,它们是区分大小写的。

%a星期几的简写

%A星期几的全称

%b月份的简写

%B月份的全称

%c标准的日期的时间串

%C年份的前两位数字

%d十进制表示的每月的第几天

%D月/天/年

%e在两字符域中,十进制表示的每月的第几天

%F年-月-日

%g年份的后两位数字,使用基于周的年

%G年份,使用基于周的年

%h简写的月份名

%H24小时制的小时

%I12小时制的小时

%j十进制表示的每年的第几天

%m十进制表示的月份

%M十时制表示的分钟数

%n新行符

%p本地的AM或PM的等价显示

%r12小时的时间

%R显示小时和分钟:hh:mm

%S十进制的秒数

%t水平制表符

%T显示时分秒:hh:mm:ss

%u每周的第几天,星期一为第一天(值从1到7,星期一为1)

%U第年的第几周,把星期日作为第一天(值从0到53)

%V每年的第几周,使用基于周的年

%w十进制表示的星期几(值从0到6,星期天为0)

%W每年的第几周,把星期一做为第一天(值从0到53)

%x标准的日期串

%X标准的时间串

%y不带世纪的十进制年份(值从0到99)

%Y带世纪部分的十制年份

%z,%Z时区名称,如果不能得到时区名称则返回空字符。

%%百分号

语法

strftime(format,timestamp)参数描述

format可选。规定如何返回结果。

timestamp可选。时间戳,默认是当前本地的