linux-----强大的find

j_0029.gif我又回来了。哈哈。今天我们来说一下linux中的另一个强大的find命令,灰常重要,灰常重要,灰常重要。显而易见,find就是对某一个文件或者目录的查找喽。但是它的一个显著的特点就是:一般放在后台执行,从整个文件系统中遍历,当然这样的话,它查找的速度就相对比较慢了。

find也有很多的命令,我来一一介绍一下吧。

1.find + pathname(想要查找的目录)

eg1:

wKioL1c1-s-wUqpfAAAw8pO5KtY998.png

find test:找出test目录下的所有文件

eg2:

wKiom1c9FZ_SpJaPAAAna_zHwvI551.png


find /home -path "*c":查找出/home目录下以c结尾的文件


eg3:

wKiom1c9YiOg9SEbAABUc8PKOdo828.png


find ./ -name *.txt:找出当前路径下文件后缀为.txt的文件


eg4:

wKiom1c9ZKqij7FfAABjVzGc7Ms254.png


find ../ -path '../test*' -name *.txt:在上级目录下名为'test'及子目录下找出以.txt后缀的文件

find ../ -path '../test*' -name xu:在上级目录下名为'test'及子目录下找出名为xu的文件


2.find + -user + 文件属主(按文件属主查找文件)

eg:

wKiom1c9EQLgGyF3AABtpnQ3SDU239.png

find -user root:找出user为root权限的所有文件


3.find + -perm + 文件权限(按文件权限查找文件)

eg:

wKiom1c9FEeRi8fPAABWcGWVsyA377.png

find -perm 644:权限为644的文件

find -perm 755:权限为755的文件


4.find + -group + 权限(按所属组的权限查找文件)

eg1:

wKioL1c9aAHgp7DhAACyO6vTCMw827.png


find -group root:找出所属组权限为root的文件

find -group admin:找出所属组权限为admin的文件


5.path与prune的结合(prune是删除,减去的意思哦)

wKioL1c9afyDfmAuAAB87334LrI894.png

find ./ -path './xu.txt*' -a -prune -o -name *.txt -print:除去xu.txt及子目录下找后缀名为.txt的文件

find ./ -path './xu*' -a -prune -o -name *.txt -print:除去xu及子目录下找后缀名为.txt的文件,虽然这里没有直接包含xu.txt,但是xu*的意思包含了.txt的文件,所以没有找到,当然就没有显示出

find ./ -path './test*' -a -prune -o -name *.txt -print:除去test及子目录下找后缀名为.txt的文件,不包含xu.txt,所以就正确的输出了后缀名为.txt的文件


6.find + -mtime + -n(+n)  按照文件的更改时间来查找文件,-n表示文件更改时间距现在n天以内,+ n表示文件更改时间距现在n天以前。find命令还有-atime和-ctime选项,但它们都和-mtime选项相同。

atime的意思是access time,即文件的最近的一次访问时间,+n意思为查找n天以前的文件,-n为查找n天以内的文件。

find命令加选项-ctime,这里的-ctime是change time。

wKiom1c9bf-xqOifAAA3H5ar3H4135.png

find -mtime -1:找出一天以内的文件

find -mtime +1:找出距现在一天以前的文件


7.-nogroup  查找无有效所属组的文件,即该文件所属的组在/etc/groups中不存在。

wKioL1c9eZ-BE22EAADnjTTSkh4565.png



groupadd test:创建一个组test。

chgrp test test.c:改变所属组。

groupdel test:删除test组,使其变为无效组。

find -nogroup:找到无效组的文件。

8.find + -nouser   查找无有效属主的文件,即该文件的属主在/etc/passwd中不存在。

wKiom1c9e7TReor7AACk4iFq2i4859.png


useradd ooo:添加用户。

chown ooo test.c:修改test.c的用户名为ooo。

userdel ooo:删除用户ooo,使其成为无效的用户。

find -nouser:查找无效的用户。


9.find + -newer file1  查找更改时间比文件file1新的文件。

eg1:

wKiom1c9qDuCkVJ2AABRf6l-5c4140.png


eg2:


wKiom1c-vsXQsYbhAAFsR9sE90g967.png

 

 find . -newer file1 ! -newer file2:找出比file1新,比file2旧的文件。

10.find + -type  查找某一类型的文件,诸如:

b -块设备文件。

d - 目录。 

c - 字符设备文件。

p - 管道文件。 

l - 符号链接文件。

f - 普通文件。 

wKiom1c9x_fAcfD4AAEjYDHVc40426.png


11.find + -depth:在查找文件时,首先查找当前目录中的文件,然后再在其子目录中查找。


wKiom1c9yJvypadeAAApICXUnrw463.png


12.find + -mount:在查找文件时不跨越文件系统mount点。


wKioL1c9ycXAvEoeAAAdbgFPEo0302.png


13.find + -follow:如果find命令遇到符号链接文件,就跟踪至链接所指向的文件。


wKioL1c9yhvgWYsCAAAjfrZOw7Y989.png

 

今天的find就说到这里咯。当然还有些没有写上去,完了还会补充的哦。大家有什么补充的,意见或建议都可以提哦,也可以直接评论。希望亲们多多关注哦。j_0059.gifj_0059.gif



本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/382882.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C语言模拟实现标准库函数之strcmp()

strcmp() C/C函数&#xff0c;比较两个字符串 设这两个字符串为str1&#xff0c;str2&#xff0c; 若str1str2&#xff0c;则返回零&#xff1b; 若str1<str2&#xff0c;则返回负数&#xff1b; 若str1>str2&#xff0c;则返回正数。 char * my_strcmp(char *key,…

linux之task_struct

每个进程中都有一个进程控制块--PCB。PCB--维护进程相关的信息。然而&#xff0c;linux内核的进程控制块就是task_struct结构体&#xff0c;它可以保存进程的信息。 所有运行在系统里的进程都以task_struct链表的形式存在内核里。 每个进程都将它的信息放在task_struct结构体…

C语言模拟实现标准库函数之memcpy()

memcpy&#xff08;&#xff09; 1.如果我们需要对一个数组初始化&#xff0c;把数组的内容全部置0&#xff0c;那么能不能用strcpy() int main() {char arr1[10] { 0 };char arr2[10] " abcdefg ";strcpy(arr2, arr1);system("pause");return 0; } 我…

说说堆及堆排序

堆&#xff1a;是一种数组对象&#xff0c;它可以被看成是一种二叉树结构。 我们把堆的二叉树存储方式分为两种&#xff1a;即大堆和小堆。那么问题来了&#xff0c;什么大堆&#xff1f;什么是小堆&#xff1f; 大堆&#xff1a;让每个父节点的值都大于孩子节点的值。 小堆…

linux之父子进程的输出

首先&#xff0c;我们来回忆一下父进程与子进程&#xff0c;前几节讲了如何创建子进程&#xff0c;像这样的&#xff0c;pid_t id fork(); 这样我们就创建好了一个子进程&#xff0c;然而fork()函数的返回值是什么呢&#xff1f;这里要记住&#xff1a;子进程返回0&#xff0c…

linux---谈谈vfork和fork的区别及exit与return

fork()&#xff1a;创建子进程的函数&#xff0c;是大家比较熟悉的吧。pid_t id fork(); 这里的vfork();也是创建子进程的函数。现在我们来剖析一下它们吧。 第一例&#xff1a; 先看一个fork()的例子哦。 对于fork()而言&#xff0c;创建子进程成功后直接打印出父子进程执…

C语言模拟实现标准库函数之qsort()

qsort 编译器函数库自带的快速排序函数。 void qsort(void*base,size_t num,size_t width,int(__cdecl*compare)(const void*,const void*)); 参数解释&#xff1a; void*base-待排序数组首地址size_t num-数组中待排序元素数量size_t width-各元素的占用空间大小int(__cde…

linux之管道

管道&#xff08;PIPE&#xff09;是linux中一个重要的通信方式&#xff0c;在进程中&#xff0c;我们通过从一个进程中读取到的数据转到另一个进程中的写数据中&#xff0c;这时就要有不同的进程之间共享同一份资源&#xff0c;就是所谓的进程间通信。由于进程的特点是资源独占…

linux之多线程(1)

我们之前讲了进程&#xff0c;今天我们重新认识另外一个概念---线程。我们首先会想到的是进程和线程有什么区别和联系&#xff0c;对吧&#xff1f;进程是由程序执行起来&#xff0c;跑在操作系统的&#xff0c;是系统进行资源分配和调度的基本单位。进程具有资源独占性&#x…

linux之睡眠函数(my_sleep)

我们在程序中&#xff0c;很多次用到sleep()函数&#xff0c;让它睡眠几秒后再执行该进程。今天呢&#xff0c;我要给大家实现一下sleep函数。 看看代码哦&#xff1a; 运行结果&#xff1a; 结果中每隔三秒钟&#xff0c;打印一条语句。实现了sleep(3)的功能。 关于sleep函数…

C语言 防止头文件被多次引用

comm.h和comm.c是公共模块。 test1.h和test1.c使用了公共模块。 test2.h和test2.c使用了了公共模块。 test.h和test.c使⽤用了了test1模块和test2模块。 这样最终程序中就会出现两份comm.h的内容。这样就造成了了文件内容的重复。 1.方法1 文件开头加上这一句就ok #prag…

详解强制类型转换

今天谈谈类型转换的问题吧&#xff0c;之前我们也遇到过类型转换&#xff0c;比如c语言中这样的赋值&#xff1a; 显然&#xff0c;i和j是不同类型的变量&#xff0c;但是却可以完成赋值&#xff0c;结果是这样的&#xff1a; 其实它们是做了隐式的类型转换&#xff0c;相当于&…

c++之类型萃取

刚刚我们接触过模板类&#xff0c;类似于这样的&#xff1a; 在这个类中&#xff0c;我们如何知道它是什么类型的呢&#xff1f;这里&#xff0c;我们可以在类中加入一个内嵌类型&#xff0c;如&#xff1a; 这样就可以知道它是用户自定义的还是本身类型就拥有的&#xff0c;我…

时间复杂度空间复杂度

我们编过不少代码&#xff0c;起初学习的时候我们习惯性的认为&#xff0c;只要代码能正确的运行就ok啦~很少考虑代码的优化带来的好处。今天说一下影响代码性能的两个重要指标--时间复杂度&空间复杂度。 时间复杂度&#xff1a;就是函数&#xff08;指数学中的函数&#…

C语言 函数递归例题解析

1.接受一个整形值&#xff08;无符号&#xff09;&#xff0c;把它转换为 字符并打印它模拟实现strlen()函数。3.求n的阶乘4.斐波那契数列总结 1.接受一个整形值&#xff08;无符号&#xff09;&#xff0c;把它转换为 字符并打印它 void fun(int x) {if (x > 9){fun(x/10)…

剖析printf函数

printf是什么&#xff0c;对于起初学习c语言的同学来说肯定都特别的疑惑。在这里&#xff0c;解答一下&#xff1a;它是一个函数。既然是一个函数的话&#xff0c;想必肯定有返回值和参数吧。那么它的返回值和参数是什么呢&#xff1f; 1、看一下这个例子&#xff0c;可能更好…

大端小端详解

文章目录为什么有大端小端&#xff1f;大端&#xff1a;低位放在高地址&#xff0c;高位放在低地址小端&#xff1a;低位放在低地址&#xff0c;高位放在高地址面试考点&#xff1a;代码代码2一道面试题为什么有大端小端&#xff1f; 大端&#xff1a;低位放在高地址&#xff0…

详解volatile关键字

volatile字面意思&#xff1a;易变的。在计算机里&#xff0c;是防止优化的意思&#xff0c;然而是怎么防止优化的呢&#xff1f;待我一一道来哦。 先看这样一个例子&#xff1a; <span style"font-size:18px;">#include<iostream> using namespace std…

C语言 有符号字符型输出 面试题

1.第一题 int main() {int a 128;printf("%u\n", a);system("pause"); } 输出结果 128 #include <stdio.h> #include <stdlib.h>int main() {char a 128;printf("%u\n", a);system("pause"); } 输出结果 42949671…

有趣的链表相关题型

链表&#xff1a;也是线性表的一种。形象的来说&#xff1a; 就像火车的一个个车厢一样&#xff0c;一个个的链起来的。它有一个特点&#xff1a;它的头没有前驱&#xff0c;尾没有后继。 为什么会引入链表这个概念呢&#xff1f;之前我们知道的顺序表&#xff0c;是用数组的形…