1. find
查找"文件"
根据文件的名称或者属性查找文件
man find
"语法格式:"
find [查找范围/ ./...] [参数]
"参数:"
-name 按照文件的名字查找文件
* 通配符
-iname 按照文件的名字查找(忽略大小写)
等同于 -i -name
-size 按照文件的大小查找文件
+n 大于指定大小
-n 小于指定大小
没有符号 等于
-mtime 按照修改时间查询
+(可以省略) n天以前
- n天以内
-ctime
-atime
-user 按照用户的属主查询
-group 按照用户的属组查询
-type 按照文件的类型查询
f,l,d,s,p,c,b..
-perm 按照文件的权限查询
-inum 根据index node号码查询
-a 并且(可以省略,默认是 并且)
-o 或者
-maxdepth 查询的目录深度(必须放置于第一个参数位)
-exec 将前面find处理好的结果交给其他命令继续处理
"知识储备:"
dd 生成文件
# dd if=/dev/zero of=100.txt bs=10M count=10
if:从什么地方读文件
of:写入到什么文件
bs:每次写入多少内容
count:写入多少次
"案例:"
案例1:
查询/etc目录下hosts文件
find [/etc/] -name 'hosts'
案例2:
查询/etc目录下名称中包含hosts文件
find /etc/ -name '*hosts*'
'*hosts'
案例3:要求把/etc目录下,所有的普通文件打包压缩到/tmp目录
tar -czPf /tmp/etcv2.tar.gz `find /etc/ -type f | xargs`
"知识储备:"
|:前面一个命令的结果交给后面的一个命令处理
xargs:把处理的文本变成以空格分割的一行
``:提前执行命令,然后将结果交给其他命令来处理
2. grep
Linux三剑客之一,文本过滤器(根据文本内容过滤文件)
"语法格式:"
grep [参数] [匹配规则(文本内部内容)] [操作对象]
"参数:"
-n 过滤文本时,将过滤出来的内容在文件内的行号显示出来
-A 匹配成功之后,将匹配行的后n行显示出来
-B 匹配成功之后,将匹配行的前n行显示出来
-C 匹配成功之后,将匹配行的前后各n行显示出来
-c 只显示匹配成功的行数
-o 只显示匹配成功的内容
"-v" 反向过滤(非常重要)
-q 静默输出(echo $?)
-i 忽略大小写
-l 匹配成功之后,将文本的名称打印出来
-R/r 递归匹配
# 在/etc目录下有多少个文件包含root,
# grep -rl 'root' /etc/ | wc -l
-E 使用拓展正则 等价于 egrep
"知识储备:"
$?:命令行中上一行命令执行的结果,0代表执行成功,其他数字代表执行失败
wc:匹配行数
-l 打印匹配行数
-c 打印匹配字节数
3. 正则表达式
1. 正则表达式的分类(grep)
1.普通正则表达式
2.拓展正则表达式
2. 普通正则表达式
^ 以...开头
$ 以...结尾
. 匹配除换行符以外的任意单个字符
* 匹配前导字符的任意个数
[] 某组字符串的任意一个字符
[^] 取反
[a-z]匹配小写字母
[A-Z] [0-9]
\ 取消转义
() 分组
\n 代表第n个分组
3. 拓展正则(egrep或者grep -E)
{} 匹配的次数
{n} 匹配n次
{n,} 至少匹配n次
{n,m} 匹配n到m次
{,m} 最多匹配m次,最少0次
+ 匹配至少有一个前导字符
? 匹配0个或1个前导字符
| 或
"案例:"
案例1:在/etc/passwd文件中,匹配以ftp开头的行
grep '^ftp' /etc/passwd
案例2:在/etc/passwd文件中,匹配以bash结尾的行
grep 'bash$' /etc/passwd
案例x:匹配
grep 'f*' test.txt 0和多个都匹配出来
案例3:匹配本机中有哪些ip
ip a | egrep -o '[0-9]{1,3}/.{3}[0-9]{1,3}'
案例4:将/etc/fstab中去掉包含#开头的行,且要求# 后至少有一个空格
egrep '^#\ +' /etc/fstab
案例5:找出文件中至少有一个空格的行
egrep '\ +'
案例6:将nginx.conf文件中以#开头的行和空行全部排除
egrep -v '^\ *#|^$' /etc/nginx/nginx.conf