Linux系列之查找命令
前言
Linux 有四个常用的查找命令:locate
、whereis
、which
和 find
。本文介绍它们的区别和简单用法。
locate命令
这个命令将检查你的整个文件系统,并找到该关键词的每一次出现。所以你可以想象到,结果可能是令人难以接受的。
locate keyword
locate
使用的数据库通常每天更新一次,所以如果你在搜索最近创建的东西,它可能不会在你的搜索中返回。你可以使用
updatedb
命令手动更新locate
命令的数据库。
locate aircrack-ng
whereis命令
在Linux中,可执行文件被称为二进制文件,如果你想定位一个二进制文件,whereis
比locate
更加有效。
whereis binary
这个命令将返回二进制文件的位置,以及它的源代码和手册页,如果有的话。
whereis aircrack-ng
which命令
Linux中的PATH
变量存放着操作系统寻找你在命令行中执行的命令的目录。
which binary
which
命令在你的PATH中找到一个二进制文件。如果它在当前PATH中没有找到该二进制文件,它就什么也不返回。
which aircrack-ng
这些目录通常包括/usr/bin
,但也可能包括/usr/sbin
和其他一些目录。
find命令
最强大的搜索命令是find
命令。你可以用它在任何指定的目录中搜索,并使用各种参数。
基本语法是:
find directory options expression
假设我有一个名为test.txt
的文件,我需要找到它但是不确定具体位于哪个目录下。我可以执行下面的命令,从文件系统的顶部/
开始搜索。
find / -type f -name test.txt
具体含义为:
/
表示从文件系统的顶部开始搜索。-type
是你要寻找的东西的类型。f
表示文件,b
表示块状特殊设备文件,c
表示字符特殊设备文件,d
表示目录,l
表示符号链接。-name
是你要寻找的东西的名字,结果将完全匹配。
搜索每一个目录,并从顶部开始查找,需要花费一定的时间。我们可以通过指定目录来加快速度。假设我知道该文件位于home
目录下:
time find /home -type f -name test.txt
这里我使用了time
命令,因此可以看到每个命令花费了多少时间。
find
命令只显示精确的名称匹配。如果file.txt
有不同的扩展名,它将不会被返回。我创建了另外一个文件text.conf
,现在如果我只用test.txt
作为名称进行搜索,我不再得到test.conf
文件的返回。
我们可以通过使用通配符(wildcards
)来解决这一限制。它们可以让我们匹配多个字符,并有几种不同的形式。
假设我们有一个包含cat、hat、what和bat文件的目录:
*
匹配多个字符。*at
将会匹配:cat、hat、what、和 bat。?
匹配单个字符。?at
将会匹配:cat、hat、bat,但不匹配what。[]
匹配出现在方括号内的字符。[c, b]
将会匹配cat和bat。
find /home -type f -name test.*
find
支持大量的测试,甚至是操作符。比方说我们想找到权限不是0600的所有文件和不是0700的所有目录。
find ~ \( -type f -not -perm 0600 \) -or \( -type d -not perm 0700 \)
这个命令的意思是:找到权限不是0600的所有文件或权限不是0700的所有目录。
- 在
~
目录(home)中进行查找。 \( -type f -not -perm 0600)
反斜线是对小括号的转义,我们在这里使用小括号将测试和操作符组合在一起,形成一个更大的表达式。默认情况下,find
是从左到右进行评估的。-not
告诉我们,如果结果是假的,该测试就是匹配的。-not
可以用!
来缩写。所以这部分也可以是`( -type f ! -perm 0600)` 。-or
告诉我们如果任何一个测试为真,那就匹配。可以简写为-o
。\( -type d -not perm 0700 \)
是另一个测试,和第一个测试非常相似,除了该类型为目录。
find
是一个拥有很多测试强大的命令,请务必多加研究。
总结
以上就是关于在Linux中查找东西的介绍
Linux系列之查找命令的更多相关文章
- [转帖]Linux系列之SAR命令使用详解
Linux系列之SAR命令使用详解 sar是System Activity Reporter(系统活动情况报告)的缩写.这个工具所需要的负载很小,也是目前linux中最为全面的性能分析工具之一.此款工 ...
- Linux 执行文件查找命令 which 详解
某个文件不知道放在哪里了,通常可以使用下面的一些命令来查找: which 查看可执行文件的位置 whereis 查看文件的位置 locate 配合数据库查看文件位置 find 实际搜寻硬盘查 ...
- linux下find查找命令用法
Linux下find命令在目录结构中搜索文件,并执行指定的操作.Linux下find命令提供了相当多的查找条件,功能很强大.由于find具有强大的功能,所以它的选项也很多,其中大部分选项都值得我们花时 ...
- linux下面的查找命令
在linux下面经常用查找命令,我自己最常用的是find whereis locate 关于find 我常用find的基本功能,如 find / -name filename 在某个目录下寻找文件. ...
- Linux学习之查找命令汇总
我们经常在linux要查找某个文件,但不知道放在哪里了,可以使用下面的一些命令来搜索: which 查看可执行文件的位置. whereis 查看文件的位置. ...
- linux 5个查找命令
1. find find是最常见和最强大的查找命令,你可以用它找到任何你想找的文件. find的使用格式如下: $ find <指定目录> <指定条件> <指定动作> ...
- Linux下的查找命令which、whereis、locate、find(6/20)
Linux下查找相关命令主要有以下4个:which.whereis.locate.find. (1)which [-a] cmdname1 cmdname2 ...... 命令参数: -n ...
- 【Linux】如何查找命令及历史记录history
如何查找命令及历史记录 文章目录 如何查找命令及历史记录 1.如何找到一个命令 2.命令的历史记录 3.一些实用的快捷键 4.小结 5.参考资料 如何找到一个命令.命令的历史记录.一些实用的快捷键.总 ...
- Linux的六种查找命令
http://www.ruanyifeng.com/blog/2009/10/5_ways_to_search_for_files_using_the_terminal.html 1. find fi ...
随机推荐
- jsp第一周作业
环境搭建,运行出来一个JSP页面,显式hello 英文字母表 <%@ page language="java" import="java.util.*" ...
- python基础练习题(输入三个整数x,y,z,请把这三个数由小到大输出)
day3 --------------------------------------------------------------- 实例005:三数排序 题目: 输入三个整数x,y,z,请把这三 ...
- 【ACM程序设计】前缀和
前缀和 前缀和是指某序列的前n项和,可以把它理解为数学上的数列的前n项和 作用: 一种预处理,求出的前缀和数组可以使得,输出原序列中从第l个数到第r个数和的时间复杂度变成了O(1) . 一维前缀和 ...
- hover特效
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 关于利用STL栈求解四则中缀表达式以及中缀表达式转逆波兰表达式和逆波兰表达式的求解
今天总结一下栈的一个重要应用---四则数学表达式的求解 数学表达式的求解是栈的一个重要的应用,在计算机的应用中 如果求解一个四则运算表达式,我们可能会直接写一个程序例如什么printf("% ...
- django基础--02基于数据库的小项目
摘要:简单修改.增加部分页面,了解django开发的过程.(Python 3.9.12,django 4.0.4 ) 接前篇,通过命令: django-admin startproject myWeb ...
- 面试简历书写、Flask框架介绍与快速使用、Flask演示登录页面、用户信息页面案例
今日内容概要 面试简历编写 Flask框架介绍与安装 内容详细 1.面试简历编写 # 千万不要几个小时把简历凑出来 几天到一周 # 有没有面试机会,取决于简历写得怎么样 简历写好是第一步 # 投简历的 ...
- mysql5.7介绍和安装
环境准备: 1.关闭防火墙和selinux systemctl stop firewalldsystemctl stop SElinux 2. 如果安装过mariadb需要停止且卸载服务 system ...
- skywalking 搭建链路监控
一.skywalking简介 官网:https://github.com/apache/skywalking 引用官网的架构: 二.部署OAP和UI 需使用的镜像 apache/skywalking ...
- 559. Maximum Depth of N-ary Tree - LeetCode
Question 559. Maximum Depth of N-ary Tree Solution 题目大意:N叉树求最大深度 思路:用递归做,树的深度 = 1 + 子树最大深度 Java实现: / ...