我有一些图像命名与生成uuid1字符串。例如81397018-b84a-11e0-9d2a-001b77dc0bed.jpg。我想用“find”命令找到所有这些图像:

find . -regex "[a-f0-9\-]\{36\}\.jpg".

但这并不奏效。正则表达式有问题吗?有人能帮我一下吗?


当前回答

从其他答案来看,这似乎是find的错。

但是你可以这样做:

找到。* | grep - p "[a-f0-9\-]{36}\.jpg"

您可能需要稍微调整grep,并根据需要使用不同的选项,但它是有效的。

其他回答

如果您想保持跨平台兼容性,我发现没有内置的正则表达式搜索选项可以在不同版本的find中以一致的方式工作。

与grep结合

正如@yarian所建议的,你可以运行一个包含过度的查找,然后通过grep运行输出:

找到。| grep -E '<POSIX正则表达式>'

这可能比较慢,但如果你需要使用完整的正则表达式,并且不能将搜索重新格式化为glob,则可以为你提供跨平台的正则表达式搜索

重写为一个glob

name选项与提供有限(但跨平台)模式匹配的glob兼容。

您可以在命令行上使用所有的模式,如* ?{} * *。尽管没有完整的regex那么强大,但您可能能够根据您的用例将搜索重新制定为glob。

网上搜索globs -网上有许多详细介绍全部功能的教程

在Mac OS X上(BSD find):与已接受的答案效果相同。

$ find -E . -regex ".*/[a-f0-9\-]{36}.jpg"

man find说-E使用扩展正则表达式支持

注意:要匹配完整的路径,需要使用。*/前缀:

为了便于比较,下面是GNU/Linux版本:

$ find . -regextype sed -regex ".*/[a-f0-9\-]\{36\}\.jpg"

简单的方法-你可以在开头指定.*,因为find匹配整个路径。

$ find . -regextype egrep -regex '.*[a-f0-9\-]{36}\.jpg$'

找到的版本

$ find --version
find (GNU findutils) 4.6.0
Copyright (C) 2015 Free Software Foundation, Inc.
License GPLv3+: GNU GPL version 3 or later 
<http://gnu.org/licenses/gpl.html>.
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.

Written by Eric B. Decker, James Youngman, and Kevin Dalley.
Features enabled: D_TYPE O_NOFOLLOW(enabled) LEAF_OPTIMISATION 
FTS(FTS_CWDFD) CBO(level=2)

当使用正则表达式应用查找指令时,应该使用绝对目录路径。 在你的例子中,

find . -regex "[a-f0-9\-]\{36\}\.jpg"

应该改为

find . -regex "./[a-f0-9\-]\{36\}\.jpg"

在大多数Linux系统中,正则表达式中的某些规则不能被该系统识别,因此必须显式地指出-regexty like

find . -regextype posix-extended -regex "[a-f0-9\-]\{36\}\.jpg"

有一件事我没有看到涉及的是如何结合正则表达式和正则查找语法。

例如:我想在BSD / Linux上找到核心转储文件,我改变到我想扫描的根目录。CD /然后执行:

find \( -path "./dev" -o -path "./sys" -o -path "./proc" \) -prune -o -type f -regextype sed -regex ".*\.core$" -exec du -h {} \; 2> /dev/null

因此,我使用prune命令来排除多个系统目录,然后对剩余的文件进行正则表达式。删除任何错误输出(stderr)。

重要的部分是首先使用Find语法,然后对正则表达式使用OR (-o)。