【Linux】【Shell】【Basic】文件查找locate,find
1.locate:1.1. 简介:依赖于事先构建好的索引库; 系统自动实现(周期性任务); 手动更新数据库(updatedb); 1.3 locate [OPTION]... PATTERN... -b:只匹配路径中的基名; -c:统计出共有多少个符合条件的文件; -r:BRE 2. find: 2.2. 工作特性:查找速度略慢;精确查找;实时查找; 2.3. 用法: find [OPTIONS] [查找起始路径] [查找条件] [处理动作] 查找条件:指定的查找标准,可以根据文件名、大小、类型、从属关系、权限等等标准进行;默认为找出指定路径下的所有文件; 处理动作:对符合查找条件的文件做出的操作,例如删除等操作;默认为输出至标准输出; 2.3.1. 查找条件详解:查找条件表达式包括选项和测试(测试结果通常为布尔型("true", "false")) 测试和测试组合: 与:-a, 默认组合逻辑; 或:-o 非:-not, ! 选项: 根据文件名查找: -name "pattern" -iname "pattern" 支持glob风格的通配符;*, ?, [], [^] 根据文件从属关系查找: -user USERNAME:查找属主指定用户的所有文件; -group GRPNAME:查找属组指定组的所有文件; -gid GID:查找属组指定的GID的所有文件; -nouser:查找没有属主的文件; -nogroup:查找没有属组的文件; 根据文件的类型查找: -type TYPE: f: 普通文件 d: 目录文件 l:符号链接文件 b:块设备 文件 c:字符设备文件 p:管道文件 s:套接字文件 根据文件的大小查找: -size [+|-]#UNIT 常用单位:k, M, G #UNIT:(#-1, #] -#UNIT:[0,#-1] +#UNIT:(#, oo) 根据时间戳查找: 以“天”为单位: -atime [+|-]# #:[#, #-1) -#:(#, 0] +#:(oo, #-1] -mtime -ctime 以“分钟”为单位: -amin -mmin -cmin 根据权限查找: -perm [/|-]mode mode:精确权限匹配; /mode:任何一类用户(u,g,o)的权限中的任何一位(r,w,x)符合条件即满足; 9位权限之间存在“或”关系; -mode:每一类用户(u,g,o)的权限中的每一位(r,w,x)同时符合条件即满足; 9位权限之间存在“与”关系; 2.3.1. 处理动作: -print:输出至标准输出;默认的动作; -ls:类似于对查找到的文件执行“ls -l”命令,输出文件的详细信息; -delete:删除查找到的文件; -fls /PATH/TO/SOMEFILE:把查找到的所有文件的长格式信息保存至指定文件中; -ok COMMAND {} \; :对查找到的每个文件执行由COMMAND表示的命令;每次操作都由用户进行确认; -exec COMMAND {} \; :对查找到的每个文件执行由COMMAND表示的命令; 注意:find传递查找到的文件路径至后面的命令时,是先查找出所有符合条件的文件路径,并一次性传递给后面的命令; 但是有些命令不能接受过长的参数,此时命令执行会失败;另一种方式可规避此问题: find | xargs COMMAND 3. 练习:1)查找/var目录下属主为root,且属组为mail的所有文件或目录; ~]# find /var -user root -a -group mail -ls2)查找/usr目录下不属于root, bin或hadoop的所有文件或目录;用两种方法; ~]# find /usr -not -user root -a -not -user bin -a -not -user hadoop ~]# find /usr -not \( -user root -o -user bin -o -user hadoop \) -ls 3)查找/etc目录下最近一周内其内容修改过,且属主不是root用户也不是hadoop用户的文件或目录; ~]# find /etc -mtime -7 -a -not \( -user root -o -user hadoop \) -ls ~]# find /etc -mtime -7 -a -not -user root -a -not -user hadoop -ls 4)查找当前系统上没有属或属组,且最近一周内曾被访问过的文件或目录; ~]# find / \( -nouser -o -nogroup \) -atime -7 -ls 5)查找/etc目录下大于1M且类型为普通文件的所有文件; ~]# find /etc -size +1M -type f -exec ls -lh {} \; 6)查找/etc目录下所有用户都没有写权限的文件; ~]# find /etc -not -perm /222 -type f -ls 7)查找/etc目录至少有一类用户没有执行权限的文件; ~]# find /etc -not -perm -111 -type f -ls 8)查找/etc/init.d/目录下,所有用户都有执行权限,且其它用户有写权限的所有文件; ~]# find /etc -perm -113 -type f -ls 9)找出/tmp目录下属主为非root的所有文件;10)找出/tmp目录下文件名中不包含fstab字符串的文件;11)找出/tmp目录下属主为非root,而且文件名不包含fstab字符串的文件;【Linux】【Shell】【Basic】文件查找locate,find的更多相关文章
- Linux下的文件查找类命令(转载)
如何快速有效的定位文件系统内所需要查找的文件呢?Linux为我们提供了一些文件查找类的命令,我们需要掌握以下几个命令: http://blog.csdn.net/sailor201211/articl ...
- Linux中的文件查找技巧
前言 Linux常用命令中,有些命令可以帮助我们查找二进制文件,帮助手册或源文件的位置,也有的命令可以帮助我们查找磁盘上的任意文件,今天我们就来看看这些命令如何使用. witch witch命令会在P ...
- Linux下的文件查找命令——find
Linux下几个常见的文件查找命令: which 查看可执行文件的位置 whereis 寻找特定文件,查看文件的位置 locate 配合数据库查看文件位置 find ...
- linux学习 网络系统&文件查找
被用来配置和操作网络系统的命令数目非常巨大,这里仅仅介绍一些经常会使用的 这一章会介绍ssh远程登录程序哦 ping 命令(掠过) traceroute 会显示主机到指定的主机要经过的跳数的网络流量列 ...
- Linux shell 编程文件比较
文件比较允许你测试Linux 文件系统上文件和目录的状态 比较 描述 -d file 检查file是否存在并是一个目录 -e file 检查file是否存在 -f file 检查file是否存在并是 ...
- 在window上使用 linux shell 删除文件夹递归地
目的 在windows环境下, 整理代码,代码中含有 .svn 文件夹, 此文件夹在所有受控目录下都存在, 需要统一删除. 但是对windows的shell不熟悉,想用linux rm来删除, 如何实 ...
- 3.shell编程-文件查找之find命令
3.1.语法格式 find [路劲][选项][操作] 选项参数对照表 3.2.-name 查找/etc/目录下以.conf结尾的文件 find /etc/ -name "*.conf&quo ...
- linux笔记八---------文件查找
1.find文件查找指令 > find 目录 参数 参数值,参数 参数值..... > find / -name passwd //从系统根目录开始递归查找name=p ...
- Linux shell判断文件和文件夹是否存在
shell判断文件,目录是否存在或者具有权限 #!/bin/sh myPath="/var/log/httpd/" myFile="/var /log/httpd/acc ...
随机推荐
- yrm的安装和使用
yrm的安装和使用 我们经常下载包的速度很忙有的还会卡住几十分钟,所以我们需要切换镜像,这样我们下载的速度会快很多 而yrm 是一个 yarn源管理器,允许你快速地在源间切换 安装 npm insta ...
- flower 指定app
flower 指定app # tasks.py from celery import Celery celery = Celery(broker="amqp://", backen ...
- sqlalchemy flush commit
https://segmentfault.com/q/1010000000698181 flush 将sql发送到内存 commit 真正提交
- C语言二分查找法
参考了C语言中折半查找法(二分法)的实现 二分查找算法(C语言实现) 先附上代码 #include<stdio.h> int BinSearch(int arr[],int len,int ...
- Alpine容器安装运行ssh
写在前面 本文介绍了在Alpine容器(docker)上安装运行ssh并保证外界(宿主机)能通过ssh登录的方法,给出了相应的命令.在下在探索过程中借鉴了许多前人的经验,在此先行谢过,所有参考内容都会 ...
- Spark 安装部署与快速上手
Spark 介绍 核心概念 Spark 是 UC Berkeley AMP lab 开发的一个集群计算的框架,类似于 Hadoop,但有很多的区别. 最大的优化是让计算任务的中间结果可以存储在内存中, ...
- Nginx的try_files指令使用实例
Nginx的配置语法灵活,可控制度非常高.在0.7以后的版本中加入了一个try_files指令,配合命名location,可以部分替代原本常用的rewrite配置方式,提高解析效率. try_file ...
- [bzoj1122]账本
简化问题:如果没有2操作,答案是多少贪心:修改-一定修改最前面的,修改+一定修改最后面的,正确性显然而通过1操作,要完成两步:1.让最终结果为q:2.让前缀和非负,通过贪心可以获得最小值(具体来说,假 ...
- [bzoj1303]中位数图
由于是排列,因此b一定只出现了一次,找到出现的位置并向左右扩展考虑如何判定是否满足条件,当且仅当$[左边比b小的数ls]+[右边比b小的数rs]=[左边比b大的数lb]+[右边比b大的数rb]$,暴力 ...
- idea配置MyBatis
新建工程 删掉src 创建Module 在工程中的porn.xml输入以下依赖 <?xml version="1.0" encoding="UTF-8"? ...