Linux-命令-awk

awk :解释

当调用awk时,awk会对输入进行逐行处理,所有的输出都会发送到stdout。

{print}代码块,在awk中,花括号用于将几块代码组合到一起

  1. BEGIN和END模块
    1. BEGIN:对于输入的每一行,awk都会执行BEGIN和END代码块一次。在很多情况中,可能需要awk在开始处理输入文件中的文本时,提前执行初始化。对于这种情况,awk使用BEGIN模块。
    2. END:在awk处理所有文件中的行之后,执行END代码块,END块用于执行最终计算或打印应该出现在输出流结尾的摘要信息。
  2. awk 运算
    1. 赋值运算:a+5 等价于:a=a+5;
    2. 关系运算:
    3. 正则运算:
    4. 逻辑运算:
    5. ?: 三目运算:
  3. 常用内置变量
      1. 变量名 含义
        $0 当前记录
        $1~$n 当前记录的第n个字段
        FS 分隔符,默认分隔符是空格 
        RS 输入记录分隔符,默认是换行符 \n
        NF 当前行的列数
        NR 已读取的记录数,就是行号。从1开始
        OFS 输出字段分隔符 默认是空格
        ORS 输出字段的换行符 默认是换行符\n
  4. awk数组

    对于awk '!a[$3]++',需要了解3个知识点

    1、awk数组知识,不说了
    2、awk的基本命令格式 awk 'pattern{action}' 省略action时,默认action是{print},如awk '1'就是awk '1{print}'
    3、var++的形式:先读取var变量值,再对var值+1

    通过awk去除重复行
    以数据
    1 2 3
    1 2 3
    1 2 4
    1 2 5
    为例,对于awk '!a[$3]++'
    在awk中,对于未初始化的数组变量,在进行数值运算的时候,会赋予初值0,因此a[$3]=0,++运算符的特性是先取值,后加1
    awk处理第一行时: 先读取a[$3]值再自增,a[$3]即a[3]值为空(0),即为awk '!0',即为awk '1',即为awk '1{print}'
    awk处理第二行时: 先读取a[$3]值再自增,a[$3]即a[3]值为1,即为awk '!1',即为awk '0',即为awk '0{print}'
    .............
    最后实现的效果就是对于$3是第一次出现的行进行打印,也就是去除$3重复的行



    a[$NF]+=$6是什么意思呢?
    相当于a[$NF]=a[$NF]+$6
    当a[$NF]从未出现时,a[$NF]=0,即a[$NF]=0+$6,即a[$NF]=$6
    当a[$NF]出现过时,a[$NF]将被覆盖

    [root@localhost scripts]# cat test.txt 
    0 1
    1 0
    2 3a
    3 0
    2 3b
    [root@localhost scripts]# awk 'a[$1]+=$2{print $0}' test.txt 
    0 1
    2 3a
    2 3b

  5. 注意问题:awk不支持元字符 需要添加 --posix

 

posted @ 2017-09-01 14:45  TimeTree  阅读(303)  评论(0编辑  收藏  举报