栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

Shell:在目录下的列表中查找文件

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Shell:在目录下的列表中查找文件

如果

filelist.txt
每行只有一个文件名:

find /dir | grep -f <(sed 's@^@/@; s/$/$/; s/([.[*]|])/\1/g' filelist.txt)

(该

-f
选项意味着grep搜索给定文件中的所有模式。)

的说明

<(sed 's@^@/@; s/$/$/; s/([.[*]|])/\1/g' filelist.txt)

<( ... )
被称为过程subsitution,并且有点类似
$( ... )
。这种情况是等效的(但是使用流程替换更整洁,可能更快一些):

sed 's@^@/@; s/$/$/; s/([.[*]|])/\1/g' filelist.txt > processed_filelist.txtfind /dir | grep -f processed_filelist.txt

调用

sed
运行命令
s@^@/@
s/$/$/
s/([.[*]|])/\1/g
在命令的每一行上将其
filelist.txt
打印出来。这些命令将文件名转换为与grep更好地兼容的格式。

  • s@^@/@
    表示
    /
    在每个文件名之前放置一个。(
    ^
    在正则表达式中表示“行首”)
  • s/$/$/
    表示
    $
    在每个文件名的末尾放置a 。(第一个
    $
    表示“行尾”,第二个只是字面量
    $
    ,然后由grep解释为“行尾”)。

这两个规则的结合意味着grep将只寻找像

.../<filename>
这样的匹配,因此
a.txt
不匹配
./a.txt.backup
./abba.txt

s/([.[*]|])/\1/g``
在每次出现
.
[

]
或之前放置一个
*
。Grep使用正则表达式,这些字符被认为是特殊字符,但我们希望它们是普通字符,因此我们需要对其进行转义(如果不对它们进行转义,则文件名
a.txt
将会与匹配
abtxt
)。

举个例子:

$ cat filelist.txtfile1.txtfile2.txtblah[2012].txtblah[2011].txtlastfile$ sed 's@^@/@; s/$/$/; s/([.[*]|])/\1/g' filelist.txt/file1.txt$/file2.txt$/blah[2012].txt$/blah[2011].txt$/lastfile$

然后,Grep在搜索的输出时会将输出的每一行用作模式

find



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/397487.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号