zoukankan      html  css  js  c++  java
  • awk 简单教程

    对awk -F做一个简单的介绍:

     awk -F"\t" '{print $3}'  test.txt 

    等同于

    awk -F'\t' '{print $3}'  test.txt

    ”-F“后用单/双引号均可以,结果一样。区别是:shell对单引号中的内容不解释,直接传给awk,而对双引号中的内容解释后再传给awk。 

    另外使用awk '{print $3}' OFS="\t"  test.txt也可以达到同样效果。


    如果省略不写,默认分隔符也是水平分隔符\t


    awk简明教程,一篇通:http://coolshell.cn/articles/9070.html

    简单的实例,快速上手:http://www.cnblogs.com/repository/archive/2011/05/13/2045927.html

    第二篇已引入我的文章(可直接参考):http://blog.csdn.net/longshenlmj/article/details/42394181

    awk 用法:awk ' pattern {action} ' 


    变量名 含义
    ARGC 命令行变元个数
    ARGV 命令行变元数组
    FILENAME 当前输入文件名
    FNR 当前文件中的记录号
    FS 输入域分隔符,默认为一个空格
    RS 输入记录分隔符
    NF 当前记录里域个数
    NR 到目前为止记录数
    OFS 输出域分隔符
    ORS 输出记录分隔符


    典型实例:

       awk '/101/'  file: 显示文件file中包含101的匹配行。
       awk '/101/,/105/'  file
       awk '$1 == 5'    file
       awk '$1 == "CT"' file 注意必须带双引号
       awk '$1 * $2 >100 '  file
       awk '$2 >5 && $2<=15' file

      Flag=abcd 
      awk '{print '$Flag'}' 结果为abcd 
      awk '{print "$Flag"}' 结果为$Flag

    求和:

       awk 'BEGIN{total=0}{total+=$4}END{print total}' a.txt   -----对a.txt文件的第四个域进行求和!

    • $ awk '/^(no|so)/' test-----打印所有以模式no或so开头的行。

    • $ awk '/^[ns]/{print $1}' test-----如果记录以n或s开头,就打印这个记录。

    • $ awk '$1 ~/[0-9][0-9]$/(print $1}' test-----如果第一个域以两个数字结束就打印这个记录。

    • $ awk '$1 == 100 || $2 < 50' test-----如果第一个或等于100或者第二个域小于50,则打印该行。

    • $ awk '$1 != 10' test-----如果第一个域不等于10就打印该行。

    • $ awk '/test/{print $1 + 10}' test-----如果记录包含正则表达式test,则第一个域加10并打印出来。

    • $ awk '{print ($1 > 5 ? "ok "$1: "error"$1)}' test-----如果第一个域大于5则打印问号后面的表达式值,否则打印冒号后面的表达式值。

    • $ awk '/^root/,/^mysql/'  test----打印以正则表达式root开头的记录到以正则表达式mysql开头的记录范围内的所有记录。如果找到一个新的正则表达式root开头的记 录,则继续打印直到下一个以正则表达式mysql开头的记录为止,或到文件末尾。

  • 相关阅读:
    jdk环境变量配置
    智商太低,竟然算不出病狗神题了
    HDU 1284 钱币兑换问题 母函数、DP
    linux下实现监控进程网络带宽
    编程算法
    C語言 rand函数 进阶探讨与实现
    JDBCUtil
    iOS进阶路线以及进阶书籍
    Windows平台CUDA开发之前的准备工作
    数据库中substring的用法 CONVERT(varchar(12) , getdate(), 112 )
  • 原文地址:https://www.cnblogs.com/cl1024cl/p/6205737.html
Copyright © 2011-2022 走看看