linux学习之awk find

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了linux学习之awk find相关的知识,希望对你有一定的参考价值。

1.awk这个命令主要是匹配列,grep是匹配行进行一些动作

cat data.txt | awk ‘{print $1}‘   --挑出文档中的第一列

技术分享

cat data.txt | awk ‘{print $NF}‘ --打印出文档中最后一列

awk ‘{print $NF}‘ data.txt  --与以上的操作一样

cat /etc/passwd | sed ‘s/:/ /g‘ | awk ‘{print $1}‘  显示系统上所有的用户,就是用了两个动作先将文档规范化,在将要的信息挑选出来

技术分享

cat /etc/passwd | awk -F: ‘{print $1}‘ --与一条操作结果一样,这里添加的-F参数是以:为分割并打印出了第一列


ifconfig eth0 | grep "inet addr"| sed ‘s/:/ /g‘| awk ‘{print $3}‘ --只打印出eth0的IP地址

技术分享

ifconfig eth0 | grep "inet addr" | awk ‘{print $2}‘ | awk -F: ‘{print $2}‘ --与上面一条命令一样可以实现同样的效果

awk在其中都是提取前面处理好的数据提取其中的列


df -h | grep "/$" | awk ‘{print $5}‘ | sed ‘s/%//g‘  --查看根分区的磁盘利用率

技术分享


cat data.txt | awk ‘{print $NF}‘ | sed ‘s/^/&000: /‘ --在最后一列的前面加上000:+空格

cat data.txt | awk ‘{print "000:" $NF}  ----在最后一列的前面加上000:,这个是awk自带的方法

技术分享


2.find命令,主要是用来查询系统下的一些文件或者目录

find . -name "data.txt" --查找当前目录下data.txt的文档

技术分享


find . -maxdepth 1 -type f -name "*.txt" ---在当前目录的第一级目录下查找名字为后缀是.txt的文件,增加maxdepth的参数

find . -maxdepth 1 -type f -name "*.txt" -mtime +2 --查看2天以前的,以目录范围和时间范围一起限制

技术分享

find . -maxdepth 1 -type f -name "*.txt" -mtime -1  --查看一天以内的


承接参数exec和承接命令xargs,可以将前面的命令执行的结果当做后面一个命令的操作对象

find . -maxdepth 1 -type f -name "*.txt" -mtime -1 -exec rm -rf {} \;  --删除一天以内的在一级目录下某某文件

find . -maxdepth 1 -type f -name "*.txt" -mtime -1 -exec cp {} /tmp/ \;  --在cp后面的{}就是代表前面匹配到的文件,拷贝到/tmp/下

xargs 不能承接cp和mv这样的命令,但是可以承接删除命令

find /tmp/ -maxdepth 1 -type f -name "data.txt" -mtime -1 | xargs rm -rf {} \;


find / -maxdepth 1 -size +20M -type f ---找到大于20M的文件,在根目录的一级目录下

find / -maxdepth 2 -size +20M -type f -exec mv {} /tmp/ \; --可以将这些找到的文件移动到临时文件下


以上的命令都可以承接处理,在结合一些语句就可以编写成脚本处理相应的一些数据文档

本文出自 “linux命令之sed” 博客,谢绝转载!

以上是关于linux学习之awk find的主要内容,如果未能解决你的问题,请参考以下文章

Linux学习之网络基本知识拓展学习

正则表达式学习之grep,sed和awk

linux内核学习之六 进程创建过程学习

Linux菜鸟的学习之法--纯属个人意见

Linux学习-kubernetes学习之kubectl命令

Linux学习-Docker学习之私有Registry