根据文件的名称或者属性查找文件。
语法格式: find [查找范围] [参数] 参数: -name : 按照文件的名字查找文件 * :通配符 -iname : 按照文件的名字查找文件(忽略大小写) -size : 按照文件的大小查询文件 + : 大于 - : 小于 没符号 : 等于 -mtime : 按照修改时间去查询 +(可以省略) : n 天以前 - : n 天以内 -atime :按照访问时间去查询(参数同上) -ctime :按照更改时间去查询(参数同上) -user :按照用户的属主查询 -group : 按照用户的属组查询 -type : 按照文件的类型查询 d : 文件夹 l : 链接文件 s : 套接字文件 p : 管道文件 c : 字符文件 b :磁盘文件 f : 普通文件 -perm : 按照文件的权限查询 -inum : 根据index node号码查询 -a : 并且(可以省略,默认时并且) -o : 或者 -maxdepth : 查询的目录深度(必须放置与第一个参数位) -exec : 将find处理好的结果交给其他命令继续处理。
案例演示:
案例1:查询/etc目录下hosts文件 [root@localhost ~]# find /etc/ -name 'hosts' 案例2:查询/etc目录下名称中包含hosts文件 [root@localhost ~]# find /etc/ -name '*hosts*' 案例3:要求把/etc目录下,所有的普通文件打包压缩到/tmp目录 [root@localhost /tmp]# tar -czPf /tmp/etcv2.tar.gz `find /etc/ -type f | xargs`
知识储备:
dd : 生成文件 if :从什么地方读 of : 写入到什么文件 bs : 每次写入多少内容 count : 写入多少次 | : 前面一个命令的结果交给后面一个命令处理 xargs : 把处理的文本变成以空格分割的一行 `` : 提前执行命令,然后将结果交给其他命令来处理
grep是Linux三剑客之一,是一种文本过滤器(根据文本内容过滤文件)。
Linux中grep经常搭配正则表达式一起使用,所以关于正则相关的知识请查看笔者之前的博客,里面有详细的介绍,这里就不再过多介绍了。
语法格式: grep [参数] [匹配规则] [操作对象] 参数: -n : 过滤文本时,将过滤出来的内容在文件内的行号显示出来 -A : 匹配成功之后,将匹配行的后n行显示出来 -B : 匹配成功之后,将匹配行的前n行显示出来 -C : 匹配成功之后,将匹配行的前后各n行显示出来 -c : 只显示匹配成功的行数 -o : 只显示匹配成功的内容 -v : 反向过滤 -q : 静默输出 -i : 忽略大小写 -l : 匹配成功之后,将文本的名称打印出来 -R|-r : 递归匹配 -E : 使用拓展正则表达式 等价于 egrep 需要使用拓展正则的相关符号: {} :匹配的次数 {n} : 匹配n次 {n,} :至少匹配n次 {n,m} :匹配 n 到 m 次 {,m} :最多匹配m次 + :匹配至少有一个前导字符 ? : 匹配一个或零个前导字符 | :或
知识储备:
知识储备: $? : 上一行命令执行的结果,0代表执行成功,其他数字代表执行失败。 wc : 匹配行数 -l : 打印匹配行数 -c : 打印匹配的字节数 eg:在/etc目录下,有多少个文件包含root。 grep -rl 'root' /etc/ | wc -l
搭配正则表达式相关案例演示:
案例1:在/etc/passwd文件中,匹配以ftp开头的行 grep '^ftp' /etc/passwd 案例2:在/etc/passwd文件中,匹配以bash结尾的行 grep 'bash$' /etc/passwd 案例3:匹配本机中有哪些ip ip a | grep -oE '([0-9]{1,3}\.){3}[0-9]{1,3}' 案例4:要求将/etc/fstab中的去掉包含 # 开头的行,且要求 # 后至少有一个空格 grep -vE '^#\ +' /etc/fstab 案例5:找出文件中至少有一个空格的行 grep -E '\ +' xxx 案例6:将 nginx.conf 文件中以#开头的行和空行,全部删除 grep -vE '^\ *#|^$' /etc/nginx/nginx.conf