4

我有一些文件的名称如下: 'abcdefg_y_zz.jpg' 'abcdefg' 是数字序列,而 'y' 和 'zz' 是字母。我需要获取所有以大于 10 的数字结尾的数字序列的文件。“fg”大于 10 的文件。

有没有人知道如何在 bash 脚本中做到这一点?

4

6 回答 6

2

好的,从技术上讲,根据您的所有信息...

ls | grep '[0-9]{5}[1-9][0-9]_[[:alpha:]]_[[:alpha:]]{2}.jpg'

于 2012-07-27T19:45:48.143 回答
1

这个怎么样?只排除在 f 位置为 0 的那些。

ls -1 | grep -v "?????0?_?_??.jpg"

更新 由于您想要 > 10 而不是 >= 10,因此您也需要排除 10。所以这样做:

ls -1 | grep -v "?????0*_?_??.jpg" | grep -v "??????10_?_??.jpg"
于 2012-07-27T19:26:14.963 回答
0

有更多的脚本

#!/bin/bash
for i in seq FIRST INCREMENT LAST
do
cp abcde$i_y_zz.jpg /your_new_dir //or whatever you want to do with those files
done

所以在你的例子中,带有 seq 的行将是

for i in seq 11 1 100000000
于 2012-07-27T19:35:43.133 回答
0

如果文件名按顺序命名,则此awk解决方案有效:

ls | awk 'BEGIN { FIELDWIDTHS = "5 2" } $2 > 10'

解释

  • FIELDWIDTHS = "5 2"表示$1将引用前 5 个字符和$2接下来的 2 个字符。
  • $2 > 10当字段 2 大于 10 并隐式调用默认代码块时匹配,即'{ print }'
于 2012-07-27T19:50:54.680 回答
0

只有一个过程:

ls ?????+(1[1-9]|[2-9]?)_?_??.jpg
于 2012-07-27T19:54:04.270 回答
0

到目前为止提供的所有解决方案都很好,但是任何对 shell 编程有一定经验的人都知道解析ls永远不是一个好主意,必须避免。这实际上不适用于这种情况,我们可以假设文件的名称遵循某种模式,但这是一个应该记住的规则。更多解释在这里

使用 GNU 可以更安全地实现您想要的东西find- 假设您在文件所在的目录中运行命令,它看起来像这样:

find . -regextype posix-egrep -regex '\./[0-9]{5}[1-9][0-9]_[[:alpha:]]_[[:alpha:]]{2}.jpg$'
于 2012-07-27T21:30:53.580 回答