我的编程空间,编程开发者的网络收藏夹
学习永远不晚

awk命令(1)

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

awk命令(1)

一、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

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

awk命令(1)

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

下载Word文档

猜你喜欢

2024-04-02
2024-04-02
2024-04-02
2023-10-21

Linux awk 命令详解

AWK是一种处理文本文件的语言,是一个强大的文本分析工具。之所以叫AWK是因为其取了三位创始人 Alfred Aho,Peter Weinberger, 和 Brian Kernighan 的 Family Name 的首字符awk是一个强
2023-06-05

awk命令如何使用

今天小编给大家分享一下awk命令如何使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。Awk模式Awk支持不同类型的模式,包
2023-06-27

Linux命令学习手册-awk

awk '条件类型1{动作1} 条件类型2{动作2} ...' filename功能相较于 sed 常常作用于一整个行的处理, awk 则比较倾向于一行当中分成数个『字段』来处理。描述awk 的处理流程读入第一行,并将第一行的资料填入 $0
2023-06-05

Linux中“awk”命令的用法

Linux中“awk”命令的用法,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。awk是一个强大的文本分析工具,简单来说awk就是把文件逐行读入,(空格,制表符)为默认分隔符
2023-06-05

linux中awk命令怎么用

这篇文章给大家分享的是有关linux中awk命令怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。awk是一种模式扫描和处理语言,在对数据进行分析处理时,是十分强大的工具。awk [options] patte
2023-06-09

详解Linux中的awk命令

简介awk是一个强大的文本分析工具,相对于grep的查找,sed的编辑,awk在其对数据分析并生成报告时,显得尤为强大。简单来说awk就是把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再进行各种分析处理。 awk有3个不同版本:
2022-06-04

linux awk命令如何使用

今天小编给大家分享一下linux awk命令如何使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。
2023-02-02

Unix中awk命令怎么用

小编给大家分享一下Unix中awk命令怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!awk 命令不仅提供了简单的输入字符串筛选功能,还包含提取数据列、打印简
2023-06-16

linux awk时间计算脚本及awk命令详解

在linux如果计划时间是个麻烦事, 用awk脚本如下BEGIN {FS=":";OFS=":"}{total_seconds=total_seconds+$3}total_seconds>=60 {total_seconds=total_
2022-06-04

Linux的awk命令怎么使用

今天小编给大家分享一下Linux的awk命令怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。awk是一款文本分析工具a
2023-06-28

linux中的Awk命令怎么用

这篇文章主要介绍linux中的Awk命令怎么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Awk 是一个强大的工具,可以执行某些可能由其它常见实用程序(包括 sort)来完成的任务。Awk 是个普遍存在的 Unix
2023-06-16

Linux中的awk命令全解析

Linux中的awk命令详解,是一种文本处理工具,语法简洁,内置函数丰富。常用命令包括字段命令、比较运算符、逻辑运算符和内置函数。条件语句和循环语句可用于复杂操作。示例包括从日志中提取IP地址、计算CSV文件平均年龄和从XML中提取特定节点值。高级用法还包括自定义函数、数组和正则表达式。awk功能强大,可满足各种文本处理需求。
Linux中的awk命令全解析
2024-04-02

如何使用awk的next命令

这篇文章将为大家详细讲解有关如何使用awk的next命令,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。要明白它是如何工作的, 让我们来分析一下 food_list.txt 它看起来像这样:Food Lis
2023-06-12

linux中如何使用awk命令

这篇文章将为大家详细讲解有关linux中如何使用awk命令,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。简介awk是一个强大的文本分析工具,相对于grep的查找,sed的编辑,awk在其对数据分析并生成报
2023-06-09

awk中next命令怎么使用

这篇文章主要介绍了awk中next命令怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇awk中next命令怎么使用文章都会有所收获,下面我们一起来看看吧。awk的next相当于循环中continue的作用
2023-06-27

编程热搜

目录