awk命令常用命令
发表于:2025-01-23 作者:千家信息网编辑
千家信息网最后更新 2025年01月23日,awk的基本用法格式awk 动作 文件名/文件名/awk/动作打印当前,print 打印,$0当前行[root@zhaocheng ~]# echo "awk is very useful" |awk
千家信息网最后更新 2025年01月23日awk命令常用命令
awk的基本用法
格式
awk 动作 文件名/文件名/awk/动作
打印当前,print 打印,$0当前行
[root@zhaocheng ~]# echo "awk is very useful" |awk '{print $0}'awk is very useful[root@zhaocheng ~]# cat filetest root:$1$dDTFylQ3$.vTZKpm7mrra9WMsxvBfW.:18241:0:99999:7bin:*:17834:0:99999:7:dadlp:*:17834:0:99999:7adasync:*:17834:0:99999:7:::ggshutdown:*:17834:0:99999:7::dahalt:*:17834:0:99999:7::fsdanginx:!!:18289::::::daafrabbitmq:!!:18297:::::dada
比如取这个文件的第一个域
-F 分隔符,":" 以冒号为分隔符
'{print $1}' 打印第每一列,这里就是以冒号为分隔符打印每列的第一个域
[root@zhaocheng ~]# cat filetest |awk -F ":" '{print $1}'rootbinlpsyncshutdownhaltnginxrabbitmq
比如以这个文件打印最后一个域,这里打印的时候还是要以什么为分隔符,有的可能是空格
[root@zhaocheng ~]# cat filetest |awk -F ':' '{print $NF}'7dad7adaggdafsdadaafdada
或者取中间的一个域,可以使用$(NF-1),处理的是-1行从后往前-1
[root@zhaocheng ~]# cat filetest |tail -1systemctl start mysqld[root@zhaocheng ~]# cat filetest |tail -1 |awk -F " " '{print $(NF-1)}'start
或者想知道处理的第几行,可以使用NR,这里也就是相当于加了一个")"
[root@zhaocheng ~]# cat filetest|tail -3 |awk -F " " '{print NR ") " $2 }'1) 2) 3) start
比如取ifconfig的IP,这里取IP的方法比较多
[root@zhaocheng ~]# ip a |grep eth02: eth0: mtu 1500 qdisc pfifo_fast state UP group default qlen 1000 inet 172.17.0.8/20 brd 172.17.15.255 scope global eth0这里是先取的打印每列的第2个域,使用tail -1倒数第一行,使用awk -F以/为分隔符取第一个域[root@zhaocheng ~]# ip a |grep eth0 |awk '{print $2}' |tail -1|awk -F "/" '{print $1}'172.17.0.8
或者直接使用grep过滤出来,使用awk以空格为分隔符,直接取第二个域,再取/号的第一个域
[root@zhaocheng ~]# ip a |grep eth0 |grep inet |awk -F " " '{print $2}' |awk -F "/" '{print $1}'172.17.0.8
也可以使用sed取它的行数,再使用awk精确匹配
[root@zhaocheng ~]# ip a |sed -n '9p'|awk -F " " '{print $2}' |awk -F "/" '{print $1}'172.17.0.8
awk的其他变量
FS:字段分隔符,默认是空格和制表符。
RS:行分隔符,用于分割每一行,默认是换行符。
OFS:输出字段的分隔符,用于打印时分隔字段,默认为空格。
ORS:输出记录的分隔符,用于打印时分隔记录,默认为换行符。
OFMT:数字输出的格式,默认为%.6g。
比如打印出这个文件中带有nginx子段的所有行
[root@zhaocheng ~]# awk -F ":" '/nginx/ {print $0}' filetest nginx:!!:18289::::::daafdadad:nginx:sdada
比如打印filetest文件第三行以前的行,以:为分隔符打印第三个域
[root@zhaocheng ~]# awk -F ":" 'NR >3 {print $3}' filetest 1783417834178341828918297sdada
分隔符
文件
空格
字段
输出
一行
冒号
动作
换行符
文件名
时分
格式
处理
命令
精确
三个
也就是
制表符
变量
数字
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
妄想山海服务器满了怎么进去
国家第一届网络安全
怎么验证新建的数据库连接
耐药数据库ARDB
小学网络安全管理制度
网络安全工作四个方面
网络安全教育团会稿
ibm服务器不亮硬盘灯
日语专业加软件开发找工作
山东菏泽服务器虚拟主机
气动数据库 datcom
应用网络安全设计
河北语音网络技术服务优势
网络安全行为审计系统视频
极限国度试玩版连不上服务器
sql 服务器下载
把软件开发部调离
上传war云服务器ecs
菏泽微信小程序软件开发系统
数据库的个人介绍
长沙银行外包软件开发
贵州华通网络技术有限公司
公安厅网络安全中心
隆昌市网络安全中心
软件开发平常怎样工作
工作App服务器登不上
互联网科技数据安全吗
玉山软件开发文档
软件开发倒排工期模板
分布式数据库实现视频监控