find
根据文件的名称或属性查找文件。
格式 :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 处理好的结果交给其他命令继续处理。
知识储备 :
dd :生成文件
if :从什么地方读
of :写入到什么文件
bs :每次写入多少内容
count :写入多少次
案例1:查询/etc目录下hosts文件
[root@localhost ~]# find /etc/ -name 'hosts'
/etc/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`
知识储备 :
| :前面一个命令的结果给后面一个命令处理
xargs :把处理的文件变成以空格分割的一行
`` :提前执行命令,然后将结果交给其他命令来处理
grep
三剑客之一,文件过滤器(根据文本内容过滤文件)。
格式 :grep [参数] [匹配规则] [操作对象]
参数 :
-n :过滤文本时,将过滤出来的内容在文件内的行号显示出来
-A :匹配成功之后,将匹配行的后n行显示出来
-B :匹配成功之后,将匹配行的前n行显示出来
-C :匹配成功之后,将匹配行的前后各n行显示出来
-c :只显示匹配成功的行数
-o :只显示匹配成功的内容
-v :反向过滤
-q :静默输出
-i :忽略大小写
-l :匹配成功之后,将文本的名称打印出来
-R|-r :递归匹配
-E :使用拓展正则 等价于 egrep
知识储备:
$? : 上一行命令执行的结果,0代表执行成功,其他数字代表执行失败。
wc : 匹配行数
-l : 打印匹配行数
-c : 打印匹配的字节数
在/etc目录下,有多少个文件包含root。
grep -rl 'root' /etc/ | wc -l
正则表达式
1、正则表达式的分类(grep)
1、普通正则表达式
2、拓展正则表达式
2、普通正则表达式
^ :以某字符开头
$ :以某字符结尾
. :
* :匹配前导字符的任意个数
[] : 某组字符串的任意一个字符
[^] : 取反
[a-z] : 匹配小写字母
[A-Z] : 匹配大写字母
[a-zA-Z]: 匹配字母
[0-9] : 匹配数字
\ : 取消转义
() : 分组
\n : 代表第n个分组
3、拓展正则
{} :匹配的次数
{n} : 匹配n次
{n,} :至少匹配n次
{n,m} :匹配 n 到 m 次
{,m} :最多匹配m次
+ :匹配至少有一个前导字符
? : 匹配一个或零个前导字符
| :或
案例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