这是一个日志过滤脚本,主要是过滤有报错的行
想问一下,这种写法是什么? 函数吗?还是啥,也没有搜到有相关的教程!
# REGED代表匹配到的内容
HELLO="
a.*
b.*
c.*
"
SCRIPTS=$(echo "$HELLO" | awk ' $1 { print "$0~/"$1"/ { count[\""$1"\"]++ }" }')
# cat内容代表日志文件的名字
cat "
a1.txt
b.txt
a2.txt
c.txt
d.txt
" |
awk '
'"$SCRIPTS"'
{all++}
END {for (i in count) {printf "%4d %s\n", count[i], i
haha += count[i]
}
printf "%4d %s\n", all - haha, "unmatched"
}
'
# REGED代表匹配到的内容
HELLO="
a.*
b.*
c.*
"
这么写是啥意思?没见过,问好多人,都说是正则表达式,具体又不知道为什么,搜了相关的教程也没有搜到。
换一种写法,跑了一下还不行,还必须得这么写比如:
HELLO="a.*,b.*,c.*"
cat "
a1.txt
b.txt
a2.txt
c.txt
d.txt
" |
awk '
'"$SCRIPTS"'
{all++}
END {for (i in count) {printf "%4d %s\n", count[i], i
haha += count[i]
}
printf "%4d %s\n", all - haha, "unmatched"
}
'
#####这里cat的是日志列表,横着写不行吗?
cat "
a1.txt
b.txt
a2.txt
c.txt
d.txt
"