[英]List files using regex in bash | ignore file having certain characters
我是正则表达式的新手,我想列出与给定正则表达式匹配的文件。 我有一些示例文件,如下图所示
我想要正则表达式,它应该返回下面提到的文件:
test1.csv test2.csv test3.csv test9.csv.tt
我想为此使用 find 命令,我也尝试使用下面提到的 find 命令,但无法达到我的预期结果
find . -maxdepth 1 -type f -name "**test[0-9]*[^-a-zA-Z_]***.csv*" -exec ls -l {} +
我想使用相同的 commnad 来实现我的预期输出,只是我想要正确的正则表达式。
任何人有任何想法请帮忙!
使用find
,您可以尝试:
find . -type f -regex ./test[0-9]\\*.csv.\\* -exec ls -l {} +
或者,使用sed
,您可以尝试
$ ls -l | sed '/^d/d;/ test[0-9]*\\.csv.*/!d'
(不确定数字是否是强制性的——如果是,则将*
替换为+
)
此sed
有 2 个命令。
/^d/d
删除任何以d
开头的行(排除目录)/ test[0-9]*\\.csv.*/!d
删除与您要过滤的正则表达式不匹配的任何行。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.