寻找返回目录中最新文件的命令。
没有看到ls的limit参数…
寻找返回目录中最新文件的命令。
没有看到ls的limit参数…
当前回答
假设您不关心以a开头的隐藏文件。
ls -rt | tail -n 1
否则
ls -Art | tail -n 1
其他回答
关于可靠性注意事项:
由于换行符和文件名中的任何字符一样有效,任何依赖于行(如基于头/尾的行)的解决方案都是有缺陷的。
在GNU ls中,另一个选项是使用——quote -style=shell-always选项和一个bash数组:
eval "files=($(ls -t --quoting-style=shell-always))"
((${#files[@]} > 0)) && printf '%s\n' "${files[0]}"
(如果您还想考虑隐藏文件,则在ls中添加-A选项)。
如果您希望限制到常规文件(忽略目录、fifo、设备、符号链接、套接字……),则需要求助于GNU find。
使用bash 4.4或更新版本(用于readarray -d)和GNU coreutils 8.25或更新版本(用于cut -z):
readarray -t -d '' files < <(
LC_ALL=C find . -maxdepth 1 -type f ! -name '.*' -printf '%T@/%f\0' |
sort -rzn | cut -zd/ -f2)
((${#files[@]} > 0)) && printf '%s\n' "${files[0]}"
或递归地:
readarray -t -d '' files < <(
LC_ALL=C find . -name . -o -name '.*' -prune -o -type f -printf '%T@%p\0' |
sort -rzn | cut -zd/ -f2-)
这里最好使用zsh和它的glob限定符,而不是bash来避免所有这些麻烦:
当前目录下最新的常规文件:
printf '%s\n' *(.om[1])
包括隐藏的:
printf '%s\n' *(D.om[1])
第二个最新的:
printf '%s\n' *(.om[2])
符号链接解析后检查文件年龄:
printf '%s\n' *(-.om[1])
递归地:
printf '%s\n' **/*(.om[1])
此外,启用了补全系统(compinit和co)后,Ctrl+Xm就变成了扩展到最新文件的补全器。
So:
vi Ctrl+Xm
会让你编辑最新的文件(你也有机会看到它在你按下返回)。
vi Alt+2Ctrl+Xm
对于第二个最新的文件。
vi *.cCtrl+Xm
对于最新的c文件。
vi *(.)Ctrl+Xm
对于最新的常规文件(不是目录,也不是fifo/device…),等等。
我也需要这样做,我找到了这些命令。这些对我来说很有用:
如果你想要最后一个文件的创建日期在文件夹(访问时间):
ls -Aru | tail -n 1
如果你想要最后一个文件的内容有变化(修改时间):
ls -Art | tail -n 1
ls -lAtr | tail -1
其他解决方案不包括以“。”开头的文件。
该命令还包括'。'和'..,这可能是也可能不是你想要的:
Ls -latr | tail -1
如果你想获得最近修改的文件,也包括任何子目录,你可以用这个小的联机程序:
find . -type f -exec stat -c '%Y %n' {} \; | sort -nr | awk -v var="1" 'NR==1,NR==var {print $0}' | while read t f; do d=$(date -d @$t "+%b %d %T %Y"); echo "$d -- $f"; done
如果你想对已更改的文件做同样的事情,但对于已访问的文件,你只需更改
参数%Y从stat命令到%X。对于最近访问的文件,你的命令是这样的:
find . -type f -exec stat -c '%X %n' {} \; | sort -nr | awk -v var="1" 'NR==1,NR==var {print $0}' | while read t f; do d=$(date -d @$t "+%b %d %T %Y"); echo "$d -- $f"; done
对于这两个命令,如果您想列出多个文件,还可以更改var="1"参数。
使用R递归选项..你可以认为这是对好的答案的增强
ls -arRtlh | tail -50