查询一段时间内的日志
awk ‘{if ($1 <= “2015-12-21” && $1 >= “2015-12-18”) {print $0} }’ xxx.log | grep 关键字
过滤空白行 awk ‘NF’
过滤重复行 awk ‘!a[$0]++’
过滤掉最后两列 awk ‘NF-=2’
过滤掉从第一个匹配行到文件尾 awk ‘/匹配/{a=1}!a’
打印从第一个匹配行到文件尾 awk ‘/匹配/{a=1}a’ 或者 awk ‘/匹配/,0’
打印匹配行和下一行 awk ‘/匹配/{getline v;print $0"\n"v}’
打印匹配行和上一行 awk ‘/匹配/{print v"\n"$0}{v=$0}’
打印匹配行和上两行 awk ‘/匹配/{print a"\n"b"\n"$0}{a=b;b=$0}’
打印匹配的上一行 awk ‘/匹配/{print x}{x=$0}’
打印匹配的下一行 awk ‘/匹配/{getline;print}’
打印从第一个匹配A行至第一个匹配B行 awk ‘/匹配A/,/匹配B/’
仅过滤第一个匹配行 awk ‘/匹配/&&!a++{next}1’
两行合并成一行打印 awk ‘{printf NR%2?$0FS:$0RS}’
每3行插一行空行 awk ‘ORS=NR%3?"\n":"\n\n"’
打印奇数行 awk ‘a=!a’
打印偶数行 awk ‘!(a=!a)’
调换奇偶行打印 awk ‘BEGIN{OFS="\n"}{getline a;print a,$0}’
模拟 wc -l awk ‘END{print NR}’
打印单引号,print后边依次为:双引号单引号转义单引号单引号双引号 awk ‘BEGIN{print "’’’"}’
打印双引号,print后边依次为:双引号转义双引号双引号 awk ‘BEGIN{print “”"}’
以一个空行为每段文本的分割标准,统计每段文本的行数 awk ‘BEGIN{RS="";FS="\n"}{print NF}’
以一个空行为每段文本的分割标准,把一段文字整合成一行 awk -vRS="\n\n" -vOFS=" " ‘$1=$1’
列交换 awk ‘{a=$2;$2=$4;$4=a}1’
计算小数四舍五入 awk -F . ‘substr($2,0,1)>=5?a=$1+1:a=$1{print a}’
打印包含中文的行 awk ‘/[^!-~]/’
模拟tail -2 awk ‘{y=x “\n” $0; x=KaTeX parse error: Expected 'EOF', got '}' at position 2: 0}̲;END{print y}' …NF}END{print a}’
过滤file中的倒数第3、4行 awk -va=$(grep -c “” file) ‘(NR!=a-2&&NR!=a-3)’ file
只保留file的第一列(危险直接修改文件内容)awk ‘{print $1 > “file”}’ file
模拟date+%T awk ‘BEGIN{now=strftime("%T");print now}’