在进行递归调用时,ls似乎没有正确地对文件进行排序:
ls -altR . | head -n 3
如何在目录(包括子目录)中找到最近修改的文件?
在进行递归调用时,ls似乎没有正确地对文件进行排序:
ls -altR . | head -n 3
如何在目录(包括子目录)中找到最近修改的文件?
当前回答
我发现以下内容更简短,输出可解释性更强:
find . -type f -printf '%TF %TT %p\n' | sort | tail -1
给定标准化ISO格式datetimes的固定长度,字典排序就可以了,我们不需要在排序上使用-n选项。
如果你想再次删除时间戳,你可以使用:
find . -type f -printf '%TFT%TT %p\n' | sort | tail -1 | cut -f2- -d' '
其他回答
下面的命令在Solaris上运行:
find . -name "*zip" -type f | xargs ls -ltr | tail -1
我也遇到过同样的问题。我需要递归地找到最近的文件。花了大约50分钟才找到。
这里有一个小脚本来更快地完成它:
#!/bin/sh
CURRENT_DIR='.'
zob () {
FILE=$(ls -Art1 ${CURRENT_DIR} | tail -n 1)
if [ ! -f ${FILE} ]; then
CURRENT_DIR="${CURRENT_DIR}/${FILE}"
zob
fi
echo $FILE
exit
}
zob
它是一个递归函数,获取目录中最近修改的项。如果该项是一个目录,则递归调用该函数并搜索该目录,等等。
我发现以下内容更简短,输出可解释性更强:
find . -type f -printf '%TF %TT %p\n' | sort | tail -1
给定标准化ISO格式datetimes的固定长度,字典排序就可以了,我们不需要在排序上使用-n选项。
如果你想再次删除时间戳,你可以使用:
find . -type f -printf '%TFT%TT %p\n' | sort | tail -1 | cut -f2- -d' '
find . -type f -printf '%T@ %p\n' \
| sort -n | tail -1 | cut -f2- -d" "
对于一棵巨大的树,排序可能很难把所有东西都保存在内存中。
%T@像unix时间戳一样给出修改时间,sort -n按数字排序,tail -1取最后一行(最高时间戳),cut -f2 -d" "从输出中删除第一个字段(时间戳)。
编辑:就像-printf可能只在gnu中使用一样,ajreal中stat -c的使用也是如此。虽然在BSD上也可以做同样的事情,但格式化的选项是不同的(-f "%m %N"似乎是这样)
我错过了复数的部分;如果你想要更多的最新文件,只需要增加tail参数。
如果在每个文件上单独运行stat会变慢,你可以使用xargs来加快速度:
find . -type f -print0 | xargs -0 stat -f "%m %N" | sort -n | tail -1 | cut -f2- -d" "