awk介绍

awk 是一个强大的文本处理工具,它将文本逐行读入,并进行切片,默认以空白格为分割符,对单个切片进行分析,处理。

用法:

awk '{pattern + action}' {filenames}

尽管操作可能会很复杂,但语法总是这样,其中 pattern 表示 AWK 在数据中查找的内容,而 action 是在找到匹配内容时所执行的一系列命令。花括号({})不需要在程序中始终出现,但它们用于根据特定的模式对一系列指令进行分组。 pattern就是要表示的正则表达式,用斜杠括起来。

awk语言的最基本功能是在文件或者字符串中基于指定规则浏览和抽取信息,awk抽取信息后,才能进行其他文本操作。完整的awk脚本通常用来格式化文本文件中的信息。

通常,awk是以文件的一行为处理单位的。awk每接收文件的一行,然后执行相应的命令,来处理文本。

选项: 

  -F : 指定地段分割符:默认分割符为空白字符

如:[root@localhost@~]#awk '{print $2,$4}' /etc/fstab 

print :显示第2段和第4段, 对个参数之间用,号分割

输出的可以是:字符串,数值,当前字段  变量 或 表达式

awk  ‘{print "hello",$1,$2,6}’

变量:

  内建变量: 

    FS 输入分割符就等于  -F      --- awk  -v  FS=':' '{print  $1,$2,$3}'    =    awk -F: '{print $1,$2,}'

    OFS 输出分隔符   awk  -v  OFS=“:” ‘{print  $1,$2.$3}’

也可以一起设定:awk  -v FS=’:’  -v OFS=’:’  ‘{print $1,$2.$3}’  /etc/passwd 

         NF : 输出每一行统计的字段数

    NR:行数,可以设定行号

     FNR :文件中行数 各文件分别计数

    FILENAME : 文件名 每行都会显示一次文件名 有多少行显示多少次文件名

    

    ARGC:  命令行参数的个数

         ARGV : 数组 保存命令行中的个参数

    BEGIN:显示一次: awk ‘BEGIN{print }’ 

    END{}:j仅在文本处理完成后执行一次

  自定义变量:  -v  var=value

    awk -v test='hello' 'BEGIN{print test}'

     awk  'BEGIN{test="hello"; print test}'

printf 命令:格式化输出命令

  awk '{printf ARGC}' /etc/fstab

  注意 不会换行需要给出换行符\n

  3FORMAT中需要分别为后面的每一个item指定一个格式化符号

    格式化符号:

        

%c ;显示字符SACII码

                     %d  %i  ;显示十进制整数

                     %e,E  科学计数法数值显示

                     %f    显示浮点数

                     %s  显示字符串

                     %u  无符号整数

                     %% ;显示%自身

awk -F: '{printf "username:%s,uid:%d\n",$1,$3}' /etc/passwd

修饰符: #[.#]  :  第一个数字控制显示的宽度,第二个表示小数点的

awk -F: '{printf "username:%15s, uid:%15d\n",$1,$3}' /etc/passwd   实现对齐  -15 表示左对齐

操作符:

  算术操作符: +   -  *   /   ^   %

  赋值操作符 : =   +=   -=   ++   --  

  比较操作符: <   >   <=   >=   !=   ==

  逻辑操作符:&&   ||    !

  函数调用:name(参数,canshu2)

匹配条件:

    /regular/ :仅处理能够被匹配到的行: awk   ‘/^UUID/{print $1}’   /etc/fstab

    relational:关系表达式结果为真才处理,真:结果为非0值

    

awk –F:  ‘$3>=1000{print $1,$3}’   /etc/psswd

       awk  -F:  ‘$NF==”/bin/bash” {print $1,$NF}’   /etc/passwd

       line  ranges :行范围  开始行 ,结束行

       awk  -F:  ‘(NR>=2&&NR<=10){print $1}’  /etc/paswwd

1 if—else 语法

       格式  if(条件) statement  else statment

[root@localhost ~]# awk -F: '{if($3>100) print $1,$3}' /etc/passwd

uid 大于1000的显示为普通用户,否则显示root或系统用户

awk -F: '{if($3>=1000) {printf "connes user:%s id:%d\n", $1,$3} else {printf "root or sys:%s id:%d\n",$1,$3}}' /etc/passwd

$NF  表示最后一个字段    NF 是一行字段数

awk -F: '{if($NF == "/sbin/nologin") print $1}' /etc/passwd

]# df -h |awk -F'%' '/^\/dev/ {print $1}'

2 while 语句

       while(条件) statement

使用场景;对一行中多个字段逐一处理时  或对数组中多个元素逐一处理

awk '/^[[:space:]]*kernel/ {print}' /etc/grub.conf

awk '/^[[:space:]]*kernel/{i=1; while(i<=NF) {print $i,length($i); i++}}' /etc/grub.conf

awk '/^[[:space:]]*kernel/{i=1; while(i<=NF) {if(length($i)>7) {print $i,length($i)}; i++}}' /etc/grub.conf

for 语句

       for(export1;export2;export3) statement

       ]# awk '/^[[:space:]]*kernel/ {for(i=1;i<=NF;i++) {print $i,length($i)}}' /etc/grub.conf

       遍历数组中元素:  for(var  in  arry) statement

switch语句case

break  和continue  语句

next语句,提前结束直接进入下一行

[root@localhost ~]# awk -F: '{if($3%2!=0) next; print $1,$3}' /etc/passwd

数组: week[mon]=”monday”    关联数组

# awk 'BEGIN{week["mon"]="monday";week["tu"]="tusday";week["we"]="weekday";for(i in week) {print week[i]}}'

]# awk 'BEGIN{week["mon"]="monday";week["tu"]="tusday";week["we"]="weekday"; print week["mon"]}'

函数:

       内置函数:

              rand() :返回0和1之间任意数

              length():返回指定字符串长度

              sub(r,s,[t]) 以r模式来查找t字符串中匹配的内容,并将第一次出现替换为s多表达的内容

       awk  -F: ‘{print sub(o,O, $1)}’   /etc/passwd

       自定义函数:

]# netstat -tan | awk '/^tcp\>/ {print $0}'

 

转载于:https://www.cnblogs.com/huxl1/p/9108533.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值