0

在这里抨击新手。任务是在一个(相当大的)目录中查找修改日期介于不同时间对之间的所有文件。这些时间在 CSV 文件中指定为 Unix 时间戳:

1483743420,1483747020
1484348640,1484352240
1484953920,1484957520
1485559200,1485562800
1486164480,1486168080
1486769820,1486773420

我早期的想法是使用findand awk

find "$PROJECT_DIR" -type f \
-newermt "$(awk -F "","" '{print $1}' "$DATE_CSV")" -not \
-newermt "$(awk -F "","" '{print $2}' "$DATE_CSV")"

find似乎无法识别这种日期格式。更紧迫的是,此代码仅将第一个日期发送到find,其余的将被打印:

$ bash datefind.sh
find: Can't parse date/time: 1483743420
1484348640
1484953920
1485559200
1486164480
1486769820

有没有办法用一个 find 命令来做到这一点?还是我应该尝试别的?

4

1 回答 1

1

使用 GNU 查找:

PROJECT_DIR="/tmp"
DATE_CSV="file"
find "$PROJECT_DIR" \( -type f \) -a \( $(awk -F ',' 'NR==1 { print "-newermt @" $1 " -not -newermt @" $2 }; NR!=1 { print "-o -newermt @" $1 " -not -newermt @" $2 }' "$DATE_CSV") \)

来自man find

-newermt: 时间规范被解释为 GNU date 的 -d 选项的参数。

-o: 逻辑或

-a: 逻辑与


awk 的作用:

DATE_CSV="file"
awk -F ',' 'NR==1 { print "-newermt @" $1 " -not -newermt @" $2 }; NR!=1 { print "-o -newermt @" $1 " -not -newermt @" $2 }' "$DATE_CSV"

输出:

-newermt @1483743420 -不是 -newermt @1483747020
-o -newermt @1484348640 -not -newermt @1484352240
-o -newermt @1484953920 -not -newermt @1484957520
-o -newermt @1485559200 -not -newermt @1485562800
-o -newermt @1486164480 -not -newermt @1486168080
-o -newermt @1486769820 -not -newermt @1486773420
于 2018-02-04T22:25:16.513 回答