我想用我的值做一些算术运算。这是我的日志文件:
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
答案 0 :(得分:7)
正确的方法是使用正确的区域设置:
LANG=de_DE awk -P '$0 = $3 * $4'
结果
167,2
31,6
0,01
6,66
34,2
1,52
答案 1 :(得分:5)
您可以在转到tr
之前运行awk
转换:
<mylog.log tr ',' '.' | awk '{print $3*$4}'
要仅在awk
中执行此操作,您可以使用sub
:
awk '{sub(/,/, "." ,$3); print $3*$4}' mylog.log