1
行
我有这样一行提取Apache日志转换Apache日志日期时间格式使用命令
awk '{print $4}' elasticsearch.log.* | cut -c2-15 | sed -e 's/$/:00:00/
每小时日期时间的问题是,输出日期的格式像下面
07/Jul/2014:06:00:00
有没有办法使用命令行将日期时间格式转换为更常见的格式,如'YYYY-MM-DD HH:mm:ss'eg 2014-07-07 06:00:00?
的一种方式,我发现现在的问题是使用中间脚本
#!/usr/bin/env python
import sys
import re
months = {'Jan': '01', 'Feb': '02', 'Mar': '03', 'Apr': '04', 'May': '05', 'Jun': '06', 'Jul': '07', 'Aug': '08', 'Sep': '09', 'Oct': '10', 'Nov': '11', 'Dec' : '12'}
regex = re.compile("(\d{2})/(\w+)/(\d{4}):(\d{2}):(\d{2}):(\d{2})",re.IGNORECASE)
for line in sys.stdin:
try:
r = regex.search(line)
g = r.groups()
print g[2] + '-' + months[g[1]] + '-' + g[0] + ' ' + g[3] + ':' + g[4] + ':' + g[5]
except:
pass
但我正在寻找,如果有一个更短的方式