ICode9

精准搜索请尝试: 精确搜索
首页 > 系统相关> 文章详细

Linux三剑客之一awk

2021-12-22 18:36:54  阅读:152  来源: 互联网

标签:passwd 分隔符 NF etc awk Linux print 三剑客


awk

 

  grep、sed和awk都是读一行处理一行,直至处理完成

定义

  格式化文本

 

格式

  awk [参数][分隔符] '{[处理规则]}' [操作对象]

  awk [参数][分隔符] '{BEGIN{开始初需要的处理}/定位/{循环}END{结束前需要的处理}}' [操作对象]

 

参数

  -F  :指定文本中的分隔符(默认是以空格作为分隔符)

 

  案例:打印系统所有用户的解析器

    awk -F: '{print $NF}' /etc/passwd

 

生命周期

  1.读取一行作为待处理文本

  2.把刚刚读取进来的文本进行分解

  3.再使用处理规则处理待处理文本

  4.处理完,赋值给$0

  5.把处理完成之后的所有的数据交给END{}来再次处理

 

预定义变量

  $0   :当前行所有数据

    awk -F: '{print $0, "---"}' /etc/passwd  # 每行后面加上---

    是默认以空格作为分隔符拼接的意思

 

  $n  :第n列

    awk -F: '{print $1}' /etc/passwd  # 第一列

 

  NF  :记录当前行的字段数(就是分隔符分了多少段数)

    awk -F: '{print NF}' /etc/passwd  # 每行分了多少段

    awk -F: '{print $NF}' /etc/passwd  # 只显示最后一列

 

  NR  :记录行号

    awk -F: '{print NR}' /etc/passwd  # 给每行递增编号

 

  FS  :指定文本中的分隔符(默认空格)(与-F的作用相似 , 但优先级比之优先)

    定义在BEGIN{FS="指定原文本内分隔符"}中

    awk 'BEGIN{FS=":"}{print $NF, $1}' /etc/passwd  # 以“:”读取最后一列和第一列

 

  OFS :指定读取处理出来的文本中使用的分隔符(默认空格)

    定义在BEGIN{FS="指定新文本中分隔符"}中

    awk -F: 'BEGIN{OFS=" >>> "}{print $NF, $1}' /etc/passwd  # 读取最后一列和第一列中间使用>>>拼接在一起

 

处理规则中执行顺序

  awk [参数][分隔符] '{BEGIN{开始初需要的处理}/定位/{循环}END{结束前需要的处理}}' [操作对象]

    BEGIN{}  :开始前需要的处理

    //     :定位

    {}     :循环

    END{}     :结束前需要的处理

 

中的函数 

  awk -F: 'BEGIN{OFS=" | "}{printf "|%+15s|%-15s|\n", $NF,$1}' /etc/passwd

    print    :打印

    printf   :格式化打印

    %s       :字符串

    %d       :数字

    -           :左对齐

    +          :右对齐

    15        :至少占用15字符

 

定位

  1.正则表达式

    awk -F: '/root/{print $0}' /etc/passwd  # 打印含root所在行的所有内容

    awk -F: '/^root/{print $0}' /etc/passwd  # 打印以root开头所在行的所有内容

 

  2.比较表达式(文本内部数据比较)

    >       :大于

    <  :小于

    >=     :大于等于

    <=     :小于等于

    ~  :表示匹配后面的正则表达式

    !~      :表示(取反)后面的正则表达式的结果

 

    案例:

      案例1:要求打印属组ID大于属主ID的行

        awk -F: '$4 > $3{print $0}' /etc/passwd  # 匹配打印出第4列比第3列大的行

 

      案例2:结尾包含bash

        awk -F: '$NF ~ /bash/{print $0}' /etc/passwd  # 读取最后一列给到后面正则表达式筛选出bash的行

 

 

      案例3:结尾不包含bash

        awk -F: '$NF !~ /bash/{print $0}' /etc/passwd  # 读取最后一列给到后面正则表达式筛选出不含bash的行

 

  3.逻辑表达式

    &&  :逻辑与

      awk -F: '$3 + $4 > 2000 && $3 * $4 > 2000{print $0}' /etc/passwd  # 必须同时满足两个条件

 

    ||     :逻辑或

      awk -F: '$3 + $4 > 2000 || $3 * $4 > 2000{print $0}' /etc/passwd  # 只要满足一个条件

 

    !      :逻辑非

      awk -F: '!($3 + $4 > 2000){print $0}' /etc/passwd  # 必须两个条件同时都不满足

 

  4.算术表达式

    +  :加

    -   :减

    *   :乘

    /   :除

    % :取余

    案例:

      案例1:要求属组 + 属主的ID 大于 2000

        awk -F: '$3 + $4 > 2000{print $0}' /etc/passwd

 

      案例2:要求属组 * 属主的ID 大于 2000

        awk -F: '$3 * $4 > 2000{print $0}' /etc/passwd

 

      案例3:要求打印偶数行

        awk -F: 'NR % 2 == 0{print $0}' /etc/passwd

 

      案例4:要求打印奇数行

        awk -F: 'NR % 2 == 1{print $0}' /etc/passwd

 

  5.条件表达式(内部数据与指定数据比较)

    == :等于(相同)

    >   :大于

    <   :小于

    >= :大于等于

    <= :小于等于

 

 

    案例:要求打印第三行

      awk -F: 'NR == 3{print $0}' /etc/passwd  # 指定 行编号为3的打印

 

  6.范围表达式

    一个选定条件到另一个选定条件之间的数据

    eg:

      awk -F: '/^root/,/^ftp/{print $0}' /etc/passwd  # 以root开头的行到以ftp开头的行中间的行

 

流程控制

  只存在循环中

  

  

 

标签:passwd,分隔符,NF,etc,awk,Linux,print,三剑客
来源: https://www.cnblogs.com/Snailsys/p/15720472.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有