在进行递归调用时,ls似乎没有正确地对文件进行排序:
ls -altR . | head -n 3
如何在目录(包括子目录)中找到最近修改的文件?
在进行递归调用时,ls似乎没有正确地对文件进行排序:
ls -altR . | head -n 3
如何在目录(包括子目录)中找到最近修改的文件?
当前回答
下面的命令在Solaris上运行:
find . -name "*zip" -type f | xargs ls -ltr | tail -1
其他回答
这给出了一个排序的列表:
find . -type f -ls 2>/dev/null | sort -M -k8,10 | head -n5
通过在sort命令中添加'-r'来颠倒顺序。如果你只想要文件名,在'| head'之前插入"awk '{print $11}' |"
我发现以下内容更简短,输出可解释性更强:
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' '
查询/target_directory目录下的所有子目录下,在过去60分钟内被修改过的文件。
$ find /target_directory -type f -mmin -60
要查找最近修改的文件,按更新时间的相反顺序排序(即,最近更新的文件在前面):
$ find /etc -type f -printf '%TY-%Tm-%Td %TT %p\n' | sort -r
我一直在使用类似的东西,以及最近修改的文件的top-k列表。对于大型目录树,避免排序会快得多。如果是最近修改最多的文件:
find . -type f -printf '%T@ %p\n' | perl -ne '@a=split(/\s+/, $_, 2); ($t,$f)=@a if $a[0]>$t; print $f if eof()'
在一个包含170万个文件的目录中,我在3.4秒内获得了最新的一个文件,与使用排序的25.5秒解决方案相比,速度提高了7.5倍。
我为这个问题写了一个pypi/github包,因为我也需要一个解决方案。
https://github.com/bucknerns/logtail
安装:
pip install logtail
用法:尾部更改文件
logtail <log dir> [<glob match: default=*.log>]
用法2:在编辑器中打开最近更改的文件
editlatest <log dir> [<glob match: default=*.log>]