网站首页 > 技术文章 正文
摘要:在Linux系统中,经常需要查找某个文件或者目录,这时就需要用到find命令了。find命令的功能是根据给定的路径和条件查找相关文件或目录,使用参数很多,并且支持正则表达式,结合管道符后能够实现更加复杂的功能。
本文主要介绍find命令的使用技巧,详细内容请参考下文。
一、访问Linux
1.登录linux
2.查看find命令
二、Find命令介绍
1.find用法格式
语法格式:find [OPTION]... [ 查找路径] [ 查找条件] [ 处理动作]
2.find查找条件
(1)根据搜索层级
-maxdepth level 最大搜索目录深度,-1指定目录为第1级当前目录
-mindepth level 最小搜索目录深度
(2)根据文件名和inode查找
-name:基于名称的精确查找,支持使用文字通配符 *, ?, [], [^]
-iname:基于名称忽略大小写的精确查找
-inum:基于inode查找
-samefile name:基于相同inode号的查找(查找硬链接)
(3)根据属主、属组查找
-user USERNAME:查找属主为指定用户(UID) 的文件
-group GRPNAME:查找属组为指定组(GID) 的文件
-uid UserID:查找属主为指定的UID 号的文件
-gid GroupID:查找属组为指定的GID 号的文件
-nouser:查找没有属主的文件
-nogroup:查找没有属组的文件
(4)根据文件类型查找
find -type
f:普通文件
d:目录文件
l:符号链接文件 (软连接)
s:套接字文件 (/dev/log)
b:块设备文件 (/dev/sda)
c:字符设备文件 (/dev/tty)
p:管道文件
(5)根据文件大小来查找
find -size [+|-]
#UNIT 根据文件大小来查找 常用单位:k, M, G,c(byte)
#UNIT: (#-1, #] 如:6k 表示(5k,6k]
-#UNIT:[0,#-1] 如:-6k 表示[0,5k]
+#UNIT:(#,∞) 如:+6k 表示(6k,∞)
(6)根据时间戳查找
以【天】为单位
-atime [+|-]#, (访问时间)
-mtime (修改时间)用法同上
-ctime(元数据改变时间)用法同上
以【分钟】为单位
-amin [+|-]#, (访问时间)
-mmin (修改时间)用法同上
-cmin(元数据改变时间)用法同上
(7)根据权限查找
-perm 根据权限查找
(8)组合条件查找
与:-a 可省略 例:find -nouser [-a] -nogroup
或:-o
非:-not, !
德· 摩根定律:
(非 A) 或 (非 B) = 非(A 且 B) !A -o !B = !(A -a B)
(非 A) 且 (非 B) = 非(A 或 B) !A -a !B = !(A -o B)
3.find处理动作
-print 默认
-delete 直接删除所查找到的文件,不询问。
-ls 长列出所查找到的文件,和ls -li 相似
-fls file 将查找到的文件长列出导入到指定文件。
> file 将查询结果导入file
>> file 将查询结果追加入file
-ok command \; 对查找到的文件当做下一命令的参数去执行(交互式)(不要忘记最后的 \; 是固定格式)
-exec command \; 对查找到的文件当做下一命令的参数去执行(非交互式)
{ }: 用于引用查找到的文件名称自身
4.find参数替换xargs
Xargs:用于产生某个命令的参数
用途:很多命令不支持管道| 来传递参数,xargs 命令能传递所有参数
比如:find -name "*.sh" | xargs ls -l
猜你喜欢
- 2024-12-27 史上最全正则详解 正则的用法
- 2024-12-27 慎用正则表达式 使用正则表达式
- 2024-12-27 Java性能调优--代码篇:优化正则表达式的匹配效率
- 2024-12-27 详细介绍一下Python爬虫中的正则表达式匹配规则?
- 2024-12-27 Word中实例演示:高级查找与高级替换等....
- 2024-12-27 再杂也无惧 在Excel高效提取数字 excel如何提取出数字
- 2024-12-27 Linux下find与exec的联手干大事 linux find -newer
- 2024-12-27 Java中如何使用正则技术提取html中的任意内容
- 2024-12-27 一看就懂 | 30分钟入门正则表达式,看这一篇就够了(值得收藏)
- 2024-12-27 VBA如何找出工作表数据中的数字,简单到不用思考
- 05-16在实际操作过程中如何避免出现SQL注入漏洞
- 05-16MySQL中 in数量限制
- 05-16一文讲懂SQL筛选子句HAVING子句
- 05-16性能调优实战:Spring Boot 多线程处理SQL IN语句大量值的优化方案
- 05-16sqlserver数据库中的模糊查询like和通配符的使用
- 05-16SQL必备 和 表关联
- 05-16SQL Server优化50法
- 05-16他们一直都在!最新强军大片来了
- 最近发表
- 标签列表
-
- cmd/c (64)
- c++中::是什么意思 (83)
- 标签用于 (65)
- 主键只能有一个吗 (66)
- c#console.writeline不显示 (75)
- pythoncase语句 (81)
- es6includes (73)
- sqlset (64)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- chromepost (65)
- c++int转char (75)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- & (66)
- java (73)
- org.redisson (64)
- js数组插入 (83)
- gormwherein (64)
- linux删除一个文件夹 (65)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)