我在 Hadoop 中有这些文件,并且想要创建日期大于setInterval
的所有文件的列表。
2016-11-21
我尝试了下面的命令,但它正在打印所有文件。如何只获得满足条件的那个
-rw-r----- 3 pharpan1 hadoop 73439 2017-01-02 15:20 manpoc_pre
-rw-r----- 3 pharpan1 hadoop 12190 2017-02-02 19:42 message.txt
-rw-r----- 3 pharpan1 hadoop 374 2016-11-14 18:18 newbin
-rw-r----- 3 pharpan1 hadoop 614 2016-11-14 18:19 newcalcpi
-rw-r----- 3 pharpan1 hadoop 154 2016-11-21 20:12 newspoc
答案 0 :(得分:3)
将输入日期作为变量传递到awk
表达式(通过-v
选项):
dateA='2016-11-21'
hdfs dfs -ls -t | awk -v dateA="$dateA" '{if ($6 > dateA) {print $8}}'
输出:
manpoc_pre
message.txt
答案 1 :(得分:0)
您可以尝试这样的事情:
首先,确定从现在到2016-11-21之间的天数:
$ (( DAYS = ($(date +"%s") - $(date +"%s" -d "2016-11-21")) / ( 24 * 3600 ) ))
$ echo $DAYS
108
接下来,使用该变量查找文件:
find /my/directory -ctime -${DAYS} -type f