linux如何查找以某个字母打头的文件或文件夹 比如,etc目录下很多文件,我想列出所有以c开头的文件或文件

linux如何查找以某个字母打头的文件或文件夹 比如,etc目录下很多文件,我想列出所有以c开头的文件或文件,第1张

ls -al |grep c* 这样就可以了,运用管道命令|。

如何使用命令行在Linux中查找文件和文件夹

1

使用查找命令,“find”命令允许您搜索知道近似文件名的文件。该命令的最简单形式在当前目录中搜索文件,并递归地通过其与所提供的搜索条件匹配的子目录。您可以按名称,所有者,组,类型,权限,日期和其他条件搜索文件。

在提示符下键入以下命令将列出当前目录中的所有文件。

“find”后的点表示当前目录。

2

要查找符合特定模式的文件,请使用-name参数。您可以使用文件名元字符(例如*),但您应该将一个转义字符(\)放在每个字符之前或将它们括在引号中。

例如,如果要在Documents目录中找到以“pro”开头的所有文件,我们将使用该cd Documents/命令更改为Documents目录,然后键入以下命令:

find . -name pro\*

列出以“pro”开头的当前目录中的所有文件。

注意:find命令默认为区分大小写。如果要搜索单词或短语不区分大小写,请使用-inamefind命令中的选项。这是-name命令的不区分大小写的版本。

3

如果find没有找到符合条件的任何文件,则不会产生任何输出。

find命令有很多选项可用于完善搜索。有关find命令的更多信息,请man find  在“终端”窗口中运行,然后按Enter键。

4

使用定位命令

locate命令比find命令更快,因为它使用了先前构建的数据库,而find命令通过所有实际目录和文件在实际系统中进行搜索。locate命令返回包含指定字符组的所有路径名的列表。

数据库从cron定期更新,但您也可以随时更新数据,以便您可以获得最新的结果。为此,请在提示符下键入以下命令:

sudo updatedb

出现提示时输入密码。

5

locate命令的基本形式从文件系统中找到包含搜索条件全部或部分内容的所有文件。

locate mydata

例如,上面的命令发现了两个包含“mydata”的文件和一个包含“数据”的文件

如果要查找包含完全唯一的搜索条件的所有文件或目录,请使用-blocate命令中的选项,如下所示。

locate-b'\ mydata'

上述命令中的反斜杠是一个globbing字符,它提供了将非特定文件名中的通配符扩展成一组特定文件名的方法。通配符是表达式被评估时可以被一个或多个字符替换的符号。最常见的通配符是问号(?),它表示单个字符,而asterisk(*)表示连续的字符串。在上面的例子中,反斜杠禁用“* mydata *”隐式替换“mydata”,所以最终只能包含“mydata”的结果。

mlocate命令是一个新的locate的实现。它索引整个文件系统,但搜索结果只包含当前用户可访问的文件。更新mlocate数据库时,它会在数据库中保留时间戳信息。这允许mlocate知道目录中的内容是否更改,而不再读取内容,并使数据库更新速度更快,对硬盘驱动器的要求也更低。

当您安装mlocate时,/ usr / bin / locate二进制文件更改为指向mlocate。要安装mlocate,如果尚未包括在Linux发行版中,请在提示符下键入以下命令。

sudo apt-get install mlocate

注意:我们将在本文后面显示一条命令,允许您确定命令的可执行文件所在的位置(如果存在)。

mlocate命令不使用与标准locate命令相同的数据库文件。因此,您可能需要在提示符下键入以下命令手动创建数据库:

sudo /etc/cron.daily/mlocate

在数据库手动创建数据库或从cron运行脚本之前,mlocate命令将不起作用。

有关locate或mlocate命令的详细信息,请键入man locate或man mlocate  在“终端”窗口中,然后按Enter键。两个命令显示相同的帮助屏幕。

6

使用哪个命令

“which”命令返回发出命令时调用的可执行文件的绝对路径。这在找到用于在桌面,面板或桌面管理器中的其他位置创建程序的快捷方式时可用于查找可执行文件的位置。例如,键入命令将which firefox 显示下图中显示的结果。

默认情况下,哪个命令只显示第一个匹配的可执行文件。要显示所有匹配的可执行文件,请使用-a以下命令的选项:

这是一个firefox

您可以一次搜索多个可执行文件,如下图所示。只显示找到的可执行文件的路径。在下面的例子中,只发现了“ps”可执行文件。

注意:哪个命令只搜索当前用户的PATH变量。如果搜索只能作为普通用户使用的root用户的可执行文件,则不会显示任何结果。

有关哪个命令的更多信息,请在终端窗口中的命令提示符下键入“man which”(不带引号),然后按Enter键。

7

使用Whereis命令

whereis命令用于查找命令的二进制文件,源文件和手册页文件所在的位置。例如,whereis firefox 在提示符下输入将显示如下图所示的结果

如果您只想要显示可执行文件的路径,而不是源和路径(man(页)),请使用该-b选项。例如,该命令whereis -b firefox将仅显示/usr/bin/firefox为结果。这很方便,因为您可能会比搜索该程序的源页面和手册页更频繁地搜索程序的可执行文件。您也可以仅搜索源文件(-s)或仅搜索手册页(-m)。

有关whereis命令的详细信息,请键入man whereis 终端窗口,然后按Enter键。

8

了解Whereis命令与哪个命令之间的区别

whereis命令显示命令的二进制,源和手册页的位置,而哪个命令仅显示命令的二进制文件的位置。

whereis命令搜索二进制,源和man文件的特定目录列表,而哪个命令搜索当前用户的PATH环境变量中列出的目录。对于whereis命令,可以在命令的手册页的FILES部分中找到具体目录的列表。

当涉及默认显示的结果时,whereis命令显示它找到的所有内容,而哪个命令只显示找到的第一个可执行文件。您可以使用-a前面讨论过的选项来更改该命令。

因为whereis命令只使用硬编码到命令中的路径,所以您可能并不总是找到您要查找的内容。如果您正在搜索一个程序,则认为可能安装在whereis命令的手册页中未列出的目录中,您可能希望使用该-a选项以查找系统中所有出现的命令,

Linux中的 grep 是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。特别是在搜索日志、配置文件、过滤时应用非常广泛。

然而这个命令有个美中不足的地方。它和其他命令配合使用时,把第一行的描述信息给过滤掉了。有时我们想要 同时输出的第一行和匹配行 。因为第一行的描述信息有助于我们理解后面每个字段的含义。

比如我们查看和sda有关的文件系统

这里的116G 58G 53G 分别表示什么? 哪个才是剩余空间?

我们希望得到结果是:

Stackoverflow给出的几种方案,grep 配合 sed 和 awk 使用。但我觉得这些方法不够好,于是我用C语言写了一个程序 grep1 。它可以 智能判断标题行 ,输出彩色标题后调用 grep 完成匹配搜索。因为是调用 grep 的,所以 grep 能用的参数这里也可以用。

为什么要强调智能判断标题行呢? 不是所有标题都在第一行,有的命令(netstat)标题在第二行。。。。。

下面给出源码(少于60行),编译后移动到 /usr/local/bin/grep1 ,PATH环境变量一般包含 /usr/local/bin

效果对比:

#include<stdlib.h>

#include<stdio.h>

#include<string.h>

#include<errno.h>

int main(int argc,char**argv)

{

    FILE *fp1,*fp2

    char buf[1024],*pstr

    int n

    n=0

    /*检查参数数量*/

    if(argc<2)

    {

        printf("lose argument!\n")

        return -1

    }

    else if(argc>2)

        if((fp2=fopen(argv[3],"a+"))==NULL)

        {

            printf("fopen %s error:%s!\n",argv[3],strerror(errno))

            return -1

        }

    if((fp1=fopen(argv[1],"r"))==NULL)

    {

        printf("fopen %s error:%s!\n",argv[1],strerror(errno))

        return -1

    }

    /*循环读取文件,直至结尾*/

    while(!feof(fp1))

    {

        fgets(buf,sizeof(buf),fp1)

        n++

        pstr=buf

        /*对每行文本进行检索,查找指定字符串*/

        while(*pstr!=NULL)

        {

            if(strncmp(pstr,argv[2],sizeof(argv[2]))==0)

            {

                printf("the number of line :%d\n%s\n\n",n,buf)

                if(fp2!=NULL)

                    fprintf(fp2,"the number of line :%d\n%s\n\n",n,buf)

                break

            }

            pstr++

        }

    }

    fclose(fp1)

    fclose(fp2)

    return 0

}


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/12101953.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-21
下一篇 2023-05-21

发表评论

登录后才能评论

评论列表(0条)

保存