一、例题

1. 文件查看

复制/etc/passwd到/opt目录下。

查看/opt/passwd文件的第6行

2.文件查找

在当前目录及子目录中,查找大写字母开头的txt文件

在/etc及其子目录中,查找host开头的文件

在$HOME目录及其子目录中,查找所有文件

在当前目录及子目录中,查找不是out开头的txt文件

忽略文件名大小写查找a.txt

在当前目录除aa之外的子目录内搜索 txt文件

在当前目录及子目录下,查找符号链接文件

查找2天内被更改过的文件

查找2天前被更改过的文件

查找超过1M的文件

3.查找文件 /usr/share/rhel.xml 中包含字符串 re 的所有行。将所有这些行的副本按原始顺序放在文件/root/files 中。

查找:

将搜索到的含有re的行输出重定向到/root/files中:

二、命令所对应的作用

1.复制文件或目录---cp命令

命令格式:cp  [选项]  源文件  目标文件

选项:

选项功能
-a通常在拷贝目录时使用。保留链接、文件属性,并且递归拷贝目录
-d拷贝时保留链接
-f覆盖已经存在的目标文件时不提示
-i在覆盖目标文件前将给出提示要求用户确认。回答y时目标文件将被覆盖,交互式拷贝。
-p除复制文件内容还将把其自改时间和访问权限也复制到新文件中。
-r给出源文件是一目录文件,此时将递归复制该目录下所有子目录和文件。此时目标文件必须是一个目录名。
-l不做拷贝,只是链接文件
 2.cat---查看文本文件的内容

命令格式:cat  [选项]  文件名列表

常用选项:

-n---对输出内容的所有行标注行号 
-b---对输出内容的非空行标注行号

3.find---对文件名称,大小,类型,权限,日期等进行搜索。

命令格式:find 搜索路径 [选项] 搜索内容  -- 如果不提供搜索路径,则在当前目录查找 

(1)按照文件名搜索

-name: 按照文件名搜索
-iname: 按照文件名搜索,不区分文件名大小写
-inum: 按照 inode 号搜索

(2)按照文件大小搜索

-size [+|-]大小: 按照指定大小搜索文件

(3)按照指定修改时间搜索文件

-atime [+|-]时间: 按照文件访问时间搜索
-mtime [+|-]时间: 按照文件数据修改时间搜索
-ctime [+|-]时间: 按照文件状态修改时间搜索

(4)按照文件类型查找

-type d: 查找目录
-type f: 查找普通文件
-type l: 查找软链接文件

(5)逻辑运算符

-a: and 逻辑与
-o: or 逻辑或
-not: not 逻辑非

(6)对应参数及作用

参数
作用

-name匹配名称
-perm匹配权限(mode为完全匹配)
-user匹配所有者
-group匹配所有者
-mtime -n +n匹配修改内容的时间(-n指 n 天内,+n指 n 天以前)
-atime -n +n匹配访问文件的时间(-n指 n 天以内,+n指 n 天以前)
-ctime -n +n匹配修改文件权限的时间(-n指 n 天内,+n指 n 天以前)
-nouser匹配无所有者文件
-nogroup匹配无所有组的文件
-newer f1 !f2匹配比文件f1新但比f2旧的文件
-type b/d/c/p/l/f匹配文件类型(后面的字母参数依次代表块设备、目录、字符设备、管道、链接文件、文本文件)
-size匹配文件的大小(+50k为查找超过50k的文件,而-50k为查找小于50k的文件)
-prune忽略某个目录
-exec……{} \;后面可跟用于进一步处理搜索结果的命令
(7)示例:

<1> 查找当前文件路径下大于50k,小于5M的文件

[root@server ~]# find -size +50k -size -5M -exec ls -lh {} \;

<2> 查找7天前删除(日志文件)

[root@server ~]# find ./ name “*.log” -mtime +6

4.grep---用于按行提取文本内容

命令格式:grep  [参数]  文件名称

选项:

参数作用
-b将可执行文件(binary)当做文本文件(test)来搜索
-c仅显示找到的行数
-i忽略大小写
-n显示行号
-v反向选择---仅列出没有“关键词”的行
示例:

<1> 查找文件/etc/passwd中以root开头的行  ^root ---正则表达式

[root@server ~]# grep "^root" /etc/passwd

<2> 查找文件/etc/passwd中/bin/bash结尾的行 

[root@server ~]# grep "/bin/bash$" /etc/passwd

<3> 统计文件中含有root的行,不区分大小写

[root@server ~]# grep -i "root" /etc/passwd

<4>  过滤配置文件中的注释和空行

[root@server ~]# grep -E -v "#|^$" /etc/ssh/sshd_config

技术
下载桌面版
GitHub
Microsoft Store
SourceForge
Gitee
百度网盘(提取码:draw)
云服务器优惠
华为云优惠券
京东云优惠券
腾讯云优惠券
阿里云优惠券
Vultr优惠券
站点信息
问题反馈
邮箱:[email protected]
吐槽一下
QQ群:766591547
关注微信