您可以从错误消息目录中创建sed脚本,然后将该sed脚本应用于日志文件。
基本上,遵循以下原则:
sed 's/(.*), 0x([0-9A-F]*)$/s%ERRORID:0x2%ERROR:1%g/' errors.txt |sed -f - logfile.txt
第一个sed脚本的输出应如下所示:
s%ERRORID:0x00000001%ERROR:Out of memory%s%ERRORID:0x00000002%ERROR:Stack overflow%s%ERRORID:0x00000031%ERROR:values of beta may cause dom%
也就是说,一个新的sed脚本指定了目录中每个错误代码的替换。
sed的方言不同,因此可能需要稍作调整。我相信Linux上的sed应该在将正则表达式中的括号分组之前使用反斜杠,并乐于接受标准输入作为该
-f选项的参数。但是,这不能移植到其他Unices(但如果需要可移植性,可以用Perl代替sed)。
编辑: 如果错误消息是相当静态的,和/或您想从标准输入中读取日志,则将生成的脚本保存在文件中;
Do this oncesed ‘s/(.), 0x([0-9A-F])$/s%ERRORID:0x2%ERROR:1%g/’ errors.txt >errors.sed
Use it many timessed -f errors.sed logfile.txt
你也可以添加
#!/usr/bin/sed -f在顶部
errors.sed和
chmod +x它,使之成为一个独立的命令脚本。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)