繁体   English   中英

使用 awk 或 xxd 或其他东西解析包含十六进制字符代码的日志

[英]Parse log containing hex character codes using awk or xxd or something

我有一个看起来像这样的文件:

.
.
.
    15 02 2013 12:05:07 [DBG] vspd[3327]: VSP   0: RX 452B30303032340D
    15 02 2013 12:05:07 [DBG] vspd[3327]: VSP   0: WX 452B30303032340D

串口通讯的嗅探器日志。

如何自动将十六进制字符代码转换为字符串?

我尝试使用这样的东西:

cat vspd.log | awk -F'(RX|WX)[[:space:]]*' '{print $2}' | awk 'BEGIN { FS = "" }{for (i = 1; i < NF; i = i + 1) a=$i$i+1;printf "%s", a; print}' | xxd -r

但它只取得了非常部分的成功,我想我把管道弄乱了。

问题是我如何转换

tail -f file.log | awk -F'(RX|WX)[[:space:]]*' '{print $2}'

变成可读的东西?

Perl解决方案:

#!/usr/bin/perl
while (<>) {
    ($prefix, $hex) = /^(.*) (.*)$/;
    $hex =~ s/(..)/chr hex $1/ge;
    print "$prefix $hex\n";
}

输出:

15 02 2013 12:05:07 [DBG] vspd[3327]: VSP   0: RX E+00024
15 02 2013 12:05:07 [DBG] vspd[3327]: VSP   0: WX E+00024

注意:您可能需要从字符串中删除最后的 \\x0D。

您确实可以使用awkxxd到达那里,这是一个示例:

<infile awk -F'(RX|WX)[[:space:]]*' '{ print $2 }' | xxd -p -r | awk 1 RS='\r'

输出:

E+00024
E+00024

旧答案

使用 GNU awk,您可以使用strtonum()来转换十六进制,例如:

function hex2str(n) {
  s = ""
  for(i=1; i<=length(n)-1; i+=2)
    s = s sprintf("%c", strtonum("0x" substr(n, i, 2)));
  return s
}

然后你可以像这样进行转换:

{ $NF = hex2str($NF) }

这是一个完整的例子:

<infile awk ' 
  function hex2str(n) {
    s = ""
    for(i=1; i<=length(n)-1; i+=2)
      s = s sprintf("%c", strtonum("0x" substr(n, i, 2)));
    return s
  }

  { $NF = hex2str($NF) }

  1
'

输出:

15 02 2013 12:05:07 [DBG] vspd[3327]: VSP 0: RX E+00024
15 02 2013 12:05:07 [DBG] vspd[3327]: VSP 0: WX E+00024

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM