查询一段时间内的日志
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=$0};END{print y}‘
 
- 打印最后一行最后一个单词 awk ‘NF{a=$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}‘
 
awk命令
原文:http://www.cnblogs.com/huangxiaoying/p/5364653.html