在Linux中使用awk命令中的tr命令

时间:2014-04-28 12:17:31

标签: linux bash awk

我想用我的值做一些算术运算。这是我的日志文件:

SYSAUX                                1050        3,04        55       996         5        95
UNDOTBS1                               420         ,08       395        25        94         6
USERS                                    5         ,01         1         4        19        81
SYSTEM                                 730        2,22         3       727         0       100
EXAMPLE                                346         ,95        36       310        10        90
UNDOTBS2                                50         ,04        38        12        77        23

我正在尝试增加第三和第四列。为了做到这一点,我必须将“,”(逗号)改为“。”(句号)。我试图在tr内运行awk命令,但它出现了一些错误:

cat mylog.log |awk '{mul= $3 * ${4}|tr  "," "\\."; print mul}'


awk: {mul= $3 * ${4}|tr  "," "\\."; print mul}
awk:             ^ syntax error
awk: {mul= $3 * ${4}|tr  "," "\\."; print mul}
awk:                ^ syntax error
awk: cmd. line:1: {mul= $3 * ${4}|tr  "," "\\."; print mul}
awk: cmd. line:1:                                          ^ unexpected newline or end of string

2 个答案:

答案 0 :(得分:7)

正确的方法是使用正确的区域设置:

LANG=de_DE awk -P '$0 = $3 * $4'

结果

167,2
31,6
0,01
6,66
34,2
1,52

awk make it less system dependant

答案 1 :(得分:5)

您可以在转到tr之前运行awk转换:

<mylog.log tr ',' '.' | awk '{print $3*$4}'

要仅在awk中执行此操作,您可以使用sub

awk '{sub(/,/, "." ,$3); print $3*$4}' mylog.log