iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >awk命令(1)
  • 876
分享到

awk命令(1)

2024-04-02 19:04:59 876人浏览 八月长安
摘要

一、awk的优点和缺点:优点:1.awk用来取列,单独取列简单方便      2.awk支持正则表达式      3.awk支持变量 

一、awk的优点和缺点:

优点:1.awk用来取列,单独取列简单方便

      2.awk支持正则表达式

      3.awk支持变量

      4.awk支持&&和||

      5.awk支持流程控制语句,如if 和if/else 条件控制

      6.awk支持循环,如while、do-while和for循环

      7.awk支持用于跳转或者退出的命令break、continue、next 和exit等

      8.awk支持函数

缺点:awk功能强大,相对来说较复杂


二、awk的命令格式:

awk '条件1 {动作1} 条件2 {动作2}...' file.txt


三、awk的用法:

1.打印匹配root的行

[root@localhost ~]# awk '/root/' /etc/passwd

root:x:0:0:root:/root:/bin/bash

operator:x:11:0:operator:/root:/sbin/nologin


2.-F选项的作用

2.1以冒号分隔,打印第一列数据;不加-F选项,默认是空格,冒号可以自定义

[root@localhost ~]# awk -F: '{print $1,$3,$5,$7}'  /etc/passwd

root 0 root /bin/bash

bin 1 bin /sbin/nologin

daemon 2 daemon /sbin/nologin

...


2.2 -F自定义分隔符,分隔数据

[root@localhost ~]# df -h

Filesystem            Size  Used Avail Use% Mounted on

/dev/mapper/VolGroup00-LogVol00

                       57G  7.2G   47G  14% /

/dev/sda1              99M   12M   82M  13% /boot

tmpfs                 252M     0  252M   0% /dev/shm


[root@localhost ~]#  df -h |grep /$ |awk '{print $4}' |awk -F"%" '{print $1}' 

14


2.3cut命令同样实现

[root@localhost ~]#  df -h |grep /$ |awk '{print $4}' |cut -d"%" -f 1 

14


2.4打印列的时候,逗号来分隔列

[root@localhost ~]# awk -F: '/root/{print $1 $3 $5 $7}' /etc/passwd

root0root/bin/bash

operator11operator/sbin/nologin


[root@localhost ~]# awk -F: '/root/{print $1,$3,$5,$7}' /etc/passwd

root 0 root /bin/bash

operator 11 operator /sbin/nologin


2.5打印列的时候,#来分隔列

[root@localhost ~]# awk -F: '/root/ {print $1"###"$7"###"$3}' /etc/passwd

root###/bin/bash###0

operator###/sbin/nologin###1


3.BEGIN和END的用法

3.1BEGIN的用法

[root@localhost ~]# df -h |grep /$ |awk '{print $4}' |awk -F"%" 'BEGIN{print "root_usage!"} {print $1}' 

root_usage!

14


3.2BEGIN和END一起用,\n用来换行

[root@localhost ~]# df -h |grep /$ |awk '{print $4}' |awk -F"%" 'BEGIN{print "\nroot_usage!"  "\n==========="} {print $1}  END{print"==========="}' 


root_usage!

===========

14

===========


4.FS、OFS、NR、NF的用法 

4.1FS等同于-F,以冒号分隔列

[root@localhost ~]# awk  'BEGIN{FS=":"} /root/ {print $1,$3,$5,$7}' /etc/passwd

root 0 root /bin/bash

operator 11 operator /sbin/nologin


4.2OFS改变默认分隔符,用#号分隔列

[root@localhost ~]# awk  -F: 'BEGIN{OFS="###"} /root/ {print $1,$3,$5,$7}' /etc/passwd

root###0###root###/bin/bash

operator###11###operator###/sbin/nologin


-v选项也可以实现

[root@localhost ~]#  awk  -F: -v OFS="###" '/root/ {print $1,$3,$5,$7}' /etc/passwd

root###0###root###/bin/bash

operator###11###operator###/sbin/nologin


4.3分号的用法

[root@localhost ~]# awk 'BEGIN {FS=":";OFS="#"} /root/ {print $1,$7}' /etc/passwd

root#/bin/bash

operator#/sbin/nologin


4.4NR用来打印行号,而且列可以自定义位置打印

[root@localhost ~]# awk -F: '/root/ {print NR,$1,$7,$5,$3}' /etc/passwd

1 root /bin/bash root 0

12 operator /sbin/nologin operator 11


[root@localhost ~]# awk '/root/ {print NR,$0}' /etc/passwd

1 root:x:0:0:root:/root:/bin/bash

12 operator:x:11:0:operator:/root:/sbin/nologin


4.5打印空行

[root@localhost ~]#awk '/^$/{print NR}' /etc/passwd



4.6这两个命令等效,但grep的效率更高

[root@localhost ~]# awk '/root/ {print NR,$0}' /etc/passwd

1 root:x:0:0:root:/root:/bin/bash

12 operator:x:11:0:operator:/root:/sbin/nologin


[root@localhost ~]# grep -n 'root' /etc/passwd

1:root:x:0:0:root:/root:/bin/bash

12:operator:x:11:0:operator:/root:/sbin/nologin


4.7NF用来打印列数,NF打印出有7列,$NF打印出最后一列

[root@localhost ~]# awk -F: '/root/ {print NR,NF,$NF,$0}' /etc/passwd

1 7 /bin/bash root:x:0:0:root:/root:/bin/bash

12 7 /sbin/nologin operator:x:11:0:operator:/root:/sbin/nologin


5.awk中的比较

<

<=

>

>=

== 等于

!=不等于

~匹配

!~不匹配


5.1打印大于等于37行的第一列

[root@localhost ~]#  awk -F: 'NR>=37 {print NR,$1}' /etc/passwd

37 xfs

38 gdm

39 pegasus

40 oracle


5.2打印大于等于60的第四列

[root@localhost shell]#cat awk.txt 

1    80 1  li

2  60   2  wang

3  70   3  zhang

4  10     4  zhao

[root@localhost shell]# awk '$2>=60 {print $4}' awk.txt

li

wang

zhang


5.3打印第一列匹配root的字段

[root@localhost ~]# awk -F: '$1=="root" {print $1,$3,$5,$7}' /etc/passwd

root 0 root /bin/bash


5.4打印全文匹配root的字段

[root@localhost ~]# awk -F: '$0~/root/ {print NR,$1,$7,$5,$3}' /etc/passwd

1 root /bin/bash root 0

12 operator /sbin/nologin operator 11


5.5打印第六列匹配root的字段

[root@localhost ~]# awk -F: '$6 ~/root/{print $1,$5,$6}' /etc/passwd

root root /root

operator operator /root


5.6打印第七行到第十二行中的字段

[root@localhost /]# awk -F : 'NR==7,NR==12 {print NR,$1,$7}' /etc/passwd

7 shutdown /sbin/shutdown

8 halt /sbin/halt

9 mail /sbin/nologin

10 news 

11 uucp /sbin/nologin

12 operator /sbin/nologin


6.if判断

6.1第一列等于root就打印

[root@localhost ~]# awk -F: '{if($1=="root")print $0}' /etc/passwd

root:x:0:0:root:/root:/bin/bash


6.2打印第一列匹配oracle的行

[root@localhost ~]# cat /etc/passwd |awk '{if($1 ~ "oracle") print NR,$0}'

40 oracle:x:500:501::/home/oracle:/bin/bash


6.3打印最后一列匹配bash的行

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

1 root /bin/bash

31 postgres /bin/bash

35 Mysql /bin/bash

40 oracle /bin/bash

您可能感兴趣的文档:

--结束END--

本文标题: awk命令(1)

本文链接: https://www.lsjlt.com/news/38152.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • sql中外码怎么设置
    sql 中外码设置步骤:确定父表和子表。在子表中创建外码列,引用父表主键。使用 foreign key 约束将外码列链接到父表主键。指定引用动作,以处理父表数据更改时的子表数据操作。 ...
    99+
    2024-05-15
  • sql中having是什么
    having 子句用于过滤分组结果,应用于分组后的数据集。它与 where 子句类似,但基于分组结果而不是原始数据。用法:1. 过滤分组后的聚合值。2. 根据分组后的...
    99+
    2024-05-15
  • 在sql中空值用什么表示
    在 sql 中,空值表示未知或不存在的值,可使用 null、空字符串或特殊值表示。处理空值的方法包括使用操作符(is null/is not null)、coalesce 函数(返回第一...
    99+
    2024-05-15
    oracle
  • sql中number什么意思
    sql 中的 number 类型用于存储数值数据,包括小数和整数,特别适合货币、度量和科学数据。其精度由 scale(小数点位数)和 precision(整数字段和小数字段总位数)决定。...
    99+
    2024-05-15
  • sql中空值赋值为0怎么写
    可以通过使用 coalesce() 函数将 sql 中的空值替换为指定值(如 0)。coalesce() 的语法为 coalesce(expression, replacement),其...
    99+
    2024-05-15
  • sql中revoke语句的功能
    revoke 语句用于撤销指定用户或角色的权限或角色成员资格。可撤销的权限包括 select、insert、update、delete 等,撤销的对象类型包括表、视图、存储过程...
    99+
    2024-05-15
    敏感数据
  • sql中REVOKE是什么意思
    revoke 是 sql 中用于撤销用户或角色对数据库对象权限的命令。它通过撤销权限类型、对象级别和目标权限来实现:权限类型:撤销 select、insert、update、d...
    99+
    2024-05-15
  • sql中sp是什么意思
    sql中的sp是存储过程的缩写,它是一种预编译的、已命名的sql语句块,存储在数据库中,可以被用户通过简单命令调用。存储过程的特点有:可重用性、模块化、性能优化、安全性、事务支持。存储过...
    99+
    2024-05-15
    敏感数据
  • sql中references是什么意思
    sql 中的 references 关键字用于在外键约束中定义表之间的父-子关系。外键约束确保子表中的行都引用父表中存在的行,从而维护数据完整性。references 语法的格式为:fo...
    99+
    2024-05-15
  • sql中判断字段为空怎么写
    sql 中可通过 4 种方法判断字段是否为空:1)is null 运算符;2)is not null 运算符;3)coalesce() 函数;4)case 语句。例如,查询所有 colu...
    99+
    2024-05-15
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作