Linux中find命令与grep命令
Linux中find命令与grep命令
- find命令
- grep命令
- 正则表达式
一、find命令
根据文件的名称或者属性查找文件
语法格式:
find [查找范围] [参数] 参数: -name:按照文件的名字查找文件 *:通配符 -iname:按照文件的名字查找文件(忽略大小写) -size:按照文件的大小查询文件 +:大于 -:小于 没符号:等于 -mtime:按照修改时间去查询 +:n天以前(可以省略) -:n天以内 -atime:按访问时间查询,用法与-mtime一致 -ctime:按修改属性时间查询,用法与-mtime一致 -user:按照用户的属主查询 -group:按照用户的属组查询 -type:按照文件的类型查询 d:文件夹 f:普通文件 l:链接文件 s:套接字文件 p:管道文件 c:字符文件 b:磁盘文件 -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命令
Linux三剑客之一,文本过滤器(根据文本内容过滤文件)
语法格式:
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次 +: 匹配至少有一个前导字符 ?: 匹配一个或零个前导字符 |: 或
4.案例:
案例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