博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
awk
阅读量:6847 次
发布时间:2019-06-26

本文共 2050 字,大约阅读时间需要 6 分钟。

awk

awk分段

指定分隔符为:,列出第一段。
awk -F ':' '{print $1}' test.txt

awk

打印第几段,就把数字改为几,打印全部改为0

列出文件所有内容。(不用F指定分隔符,默认是以空白为分隔符)

awk '{print $0}' test.txt

awk

指定分隔符为:,列出第1、3、4段。

awk -F ':' '{print $1,$3,$4}' test.txt

awk

指定分隔符为#,列出第1、3、4段,用双引号引起#号(#号可以随意更改为任意符号)

awk -F ':' '{print $1"#"$3"#"$4}' test.txt

awk

匹配出带有oo的行。

awk '/oo/' test.txt

awk

匹配出第一段带有oo的行。

awk -F ':' '$1 ~ /oo/' test.txt

awk

awk同样支持正则表达式

awk -F ':' '$1 ~ /o+/' test.txt

awk

匹配出带有root的行并列出第1/3段,匹配出带有yang的行并列出1、3、4行。(awk支持多个表达式一起写)

awk -F ':' '/root/ {print $1,$2} /yang/ {print $1,$3,$4}' test.txt

awk

匹配出带有root以及yang的行。中间用管道符 | 隔开

awk -F ':' '/root|yang/ {print $0}' test.txt

awk

列出第三段等于0的行的第一段。

awk -F ':' '$3==0 {print $1}' test.txt

awk

列出第三段大于等于1000的行的第一段。(如果这个1000加上引号那么系统就不会把它当成数字,而是当成阿斯玛的方式去计算的,也就是说会认为这个1000是字符串)

awk -F ':' '$3>=1000 {print $0}' test.txt

awk

列出第7段(不等于)不是/sbin/nologin的行。(字符串加双引号)

awk -F ':' '$7!="/sbin/nologin" {print $0}' test.txt

awk

列出第3段小于第4段的行

awk -F ':' '$3<$4' test.txt

awk

列出第3段大于5(加双引号的5算是字符)并且小于7的行。(把&&换成||就是或者的意思)

awk -F ':' '$3>"5" && $3<"7"' test.txt

awk

列出第3段大于1000或者第7段包含bash的行。

awk -F ':' '{OFS="#"} $3>1000 || $7 ~ /bash/ {print $1,$3,$7}' test.txt

awk

上面讲到在结果中每段使用#为分隔符,出了在print后面的每一段中间加#,我们还可以使用这种方法。(OFS意思是结果中指定分隔符)

awk -F ':' '{OFS="#"} {print $1,$3,$7}' test.txt

awk

我们也可以加语句进行修饰,这里就使用到了if,也可以写成下图格式,不过下图看起来生硬一点。

awk -F ':' '{OFS="#"} {if ($3>100){print $1,$2,$3,$4}}' test.txt

awk

在列出的结果中前面显示行号加冒号。(NR意思加行号)

awk -F ':' '{print NR":"$0}' test.txt

awk

在列出的结果中前面显示该行有多少段,加冒号。(NF意思加段数)

awk -F ':' '{print NF":"$0}' test.txt

awk

把行数小于等于10的列出来,也就是前十行。

awk -F ':' 'NR<=10' test.txt

awk

行数小于等于10并且第一段是root或者sync的行列出来。(或者把NR改成NF就是总段数小于等于10)

awk -F ':' 'NR<=10 && $1 ~ /root|sync/' test.txt

awk

显示(该行的行号所对应的段数内容):(该行的段数所对应的段数内容)如第一行就显示第一段加冒号加第七段。

awk -F ':' '{print sNR":"$NF}' test.txt

awk

把前三行的第一段改成root(附值之后结果的分隔符就没了,我们可以使用OFS定义一下就行了,如下图)

head -n 3 /etc/passwd | awk -F ":" '$1="root"

awk

head -n 3 test.txt | awk -F ":" '{OFS=":"} $1="root"'

awk

求出所有行的第三段的和。(tot是求和的意思,第一个大括号里的是一个循环式,每行都循环一次,第一行就是0+第三段,第二行是第一行的第三段加第二行的第三段)

awk -F ':' '{(tot=tot+$30)}; END {print tot}' test.txt

awk

转载于:https://blog.51cto.com/13658403/2108557

你可能感兴趣的文章
比起勤劳,这一原则更能让你效率翻倍?
查看>>
Python的MongoDB模块PyMongo
查看>>
图书表
查看>>
好程序员大数据入门之Hadoop技术优缺点
查看>>
轻松看懂Hashtable源码以及与HashMap的区别
查看>>
【Dubbo源码阅读系列】服务暴露之本地暴露
查看>>
Oracle常用dump命令
查看>>
C# Word转PDF/HTML/XML/XPS/SVG/EMF/EPUB/TIFF
查看>>
C# PDF Page操作——设置页面切换按钮
查看>>
LNMP笔记:安装vsftpd配置FTP账户
查看>>
(玩转zabbix)硬盘硬件健康状态监控,部件寿命监控
查看>>
思杰服务账号ctxadmin被误删的解决方法
查看>>
【Java例题】5.3 线性表的使用
查看>>
我的友情链接
查看>>
第二章 -- (第二单元)--设备权限
查看>>
【转】浅谈HTTP中Get与Post的区别
查看>>
windows2012 r2 域策略集合
查看>>
2017"百度之星"程序设计大赛 - 初赛(A)1001——HDU 6108【求因子数】【思维题】...
查看>>
取消服务器系统的 IE 安全增强(2003、2008)
查看>>
云计算项目实战之程序模块说明
查看>>