awk命令

查询一段时间内的日志

awk '{if ($1 <= "2015-12-21" && $1 >= "2015-12-18") {print $0} }'   xxx.log  | grep  关键字

 

  1. 过滤空白行   awk 'NF'
  2. 过滤重复行 awk '!a[$0]++'
  3. 过滤掉最后两列 awk 'NF-=2'
  4. 过滤掉从第一个匹配行到文件尾 awk '/匹配/{a=1}!a'
  5. 打印从第一个匹配行到文件尾 awk '/匹配/{a=1}a' 或者 awk '/匹配/,0'
  6. 打印匹配行和下一行 awk '/匹配/{getline v;print $0"\n"v}'
  7. 打印匹配行和上一行 awk '/匹配/{print v"\n"$0}{v=$0}'
  8. 打印匹配行和上两行 awk '/匹配/{print a"\n"b"\n"$0}{a=b;b=$0}'
  9. 打印匹配的上一行 awk '/匹配/{print x}{x=$0}'
  10. 打印匹配的下一行 awk '/匹配/{getline;print}'
  11. 打印从第一个匹配A行至第一个匹配B行  awk '/匹配A/,/匹配B/'
  12. 仅过滤第一个匹配行 awk '/匹配/&&!a++{next}1'
  13. 两行合并成一行打印 awk '{printf NR%2?$0FS:$0RS}'
  14. 每3行插一行空行 awk 'ORS=NR%3?"\n":"\n\n"'
  15. 打印奇数行 awk 'a=!a'
  16. 打印偶数行 awk '!(a=!a)'
  17. 调换奇偶行打印 awk 'BEGIN{OFS="\n"}{getline a;print a,$0}'
  18. 模拟 wc -l    awk 'END{print NR}'
  19. 打印单引号,print后边依次为:双引号单引号转义单引号单引号双引号  awk 'BEGIN{print "'\''"}'
  20. 打印双引号,print后边依次为:双引号转义双引号双引号 awk 'BEGIN{print "\""}'
  21. 以一个空行为每段文本的分割标准,统计每段文本的行数 awk 'BEGIN{RS="";FS="\n"}{print NF}'
  22. 以一个空行为每段文本的分割标准,把一段文字整合成一行 awk -vRS="\n\n" -vOFS=" " '$1=$1'
  23. 列交换 awk  '{a=$2;$2=$4;$4=a}1'
  24. 计算小数四舍五入 awk -F . 'substr($2,0,1)>=5?a=$1+1:a=$1{print a}'
  25. 打印包含中文的行 awk '/[^!-~]/'
  26. 模拟tail -2 awk '{y=x "\n" $0; x=$0};END{print y}'
  27. 打印最后一行最后一个单词 awk 'NF{a=$NF}END{print a}'
  28. 过滤file中的倒数第3、4行 awk -va=$(grep -c "" file) '(NR!=a-2&&NR!=a-3)'  file
  29. 只保留file的第一列(危险直接修改文件内容)awk '{print $1 > "file"}' file
  1. 模拟date+%T awk 'BEGIN{now=strftime("%T");print now}'
posted @ 2016-04-07 17:51  candice_aviva  阅读(417)  评论(0编辑  收藏  举报