查找将返回目录中单个最新文件的命令。
没有看到ls的限制参数......
答案 0 :(得分:208)
ls -Art | tail -n 1
不是很优雅,但它有效。
答案 1 :(得分:117)
ls -t | head -n1
此命令实际上在当前工作目录中提供最新修改的文件。
答案 2 :(得分:58)
这是一个递归版本(即它在某个目录或其任何子目录中找到最近更新的文件)
find $DIR -type f -printf "%T@ %p\n" | sort -n | cut -d' ' -f 2- | tail -n 1
修改:使用-f 2-
代替-f 2
,建议凯文
答案 3 :(得分:9)
我用:
ls -ABrt1 --group-directories-first | tail -n1
它只给我文件名,不包括文件夹。
答案 4 :(得分:7)
ls -lAtr | tail -1
其他解决方案不包含以'.'
开头的文件。
此命令还包括'.'
和'..'
,这可能是您想要的,也可能不是:
ls -latr | tail -1
答案 5 :(得分:6)
根据dmckee的回答缩短变体:
ls -t | head -1
答案 6 :(得分:5)
关于可靠性的说明:
由于换行符与文件名中的任何字符一样有效,因此任何依赖于基于head
/ tail
的行的解决方案都存在缺陷。
使用GNU ls
,另一种选择是使用--quoting-style=shell-always
选项和bash
数组:
eval "files=($(ls -t --quoting-style=shell-always))"
((${#files[@]} > 0)) && printf '%s\n' "${files[0]}"
(如果您还想考虑隐藏文件,请将-A
选项添加到ls
。
如果要限制常规文件(忽略目录,fifos,设备,符号链接,套接字......),则需要使用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
及其全局限定符而不是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 + X m 将成为扩展到最新文件的完成者。
所以:
vi Ctrl+Xm
会让你编辑最新的文件(在按返回之前,你也有机会看到它。)
vi Alt+2Ctrl+Xm
对于第二个最新的文件。
vi *.cCtrl+Xm
获取最新的c
文件。
vi *(.)Ctrl+Xm
用于最新的常规文件(不是目录,也不是fifo / device ...),依此类推。
答案 7 :(得分:4)
查找/排序解决方案非常有效,直到文件数量变得非常大(如整个文件系统)。使用awk代替跟踪最新文件:
find $DIR -type f -printf "%T@ %p\n" |
awk '
BEGIN { recent = 0; file = "" }
{
if ($1 > recent)
{
recent = $1;
file = $0;
}
}
END { print file; }' |
sed 's/^[0-9]*\.[0-9]* //'
答案 8 :(得分:3)
我喜欢echo *(om[1])
(zsh
语法),因为它只提供文件名而不会调用任何其他命令。
答案 9 :(得分:2)
我个人更喜欢使用尽可能少的内置bash
命令(以减少昂贵的fork和exec系统调用的数量)。要按日期排序,需要调用ls
。但是使用head
并不是必需的。我使用以下单行程序(仅适用于支持名称管道的系统):
read newest < <(ls -t *.log)
或获取最旧文件的名称
read oldest < <(ls -rt *.log)
(注意两个'&lt;'标记之间的空间!)
如果还需要隐藏文件 - 可以添加arg。
我希望这可以提供帮助。
答案 10 :(得分:2)
如果您想获取最新更改的文件(包括所有子目录),可以使用此小单行纸进行操作:
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” 参数。
答案 11 :(得分:2)
使用R递归选项..你可以认为这是对这里好答案的增强
ls -arRtlh | tail -50
答案 12 :(得分:1)
仅内置Bash,紧跟BashFAQ/003:
shopt -s nullglob
for f in * .*; do
[[ -d $f ]] && continue
[[ $f -nt $latest ]] && latest=$f
done
printf '%s\n' "$latest"
答案 13 :(得分:1)
递归:
find $1 -type f -exec stat --format '%Y :%y %n' "{}" \; | sort -nr | cut -d: -f2- | head
答案 14 :(得分:1)
ls -t -1 | sed '1q'
将显示文件夹中的最后修改项目。与grep
配对,查找包含关键字的最新条目
ls -t -1 | grep foo | sed '1q'
答案 15 :(得分:1)
尝试这个简单的命令
ls -ltq <path> | head -n 1
如果你想要文件名 - 最后修改,路径= / ab / cd / * .log
如果你想要目录名 - 最后修改,路径= / ab / cd / * /
答案 16 :(得分:0)
根据模式查找每个目录中的最新文件,例如名称以&#34; tmp&#34;结尾的工作目录的子目录; (不区分大小写):
find . -iname \*tmp -type d -exec sh -c "ls -lArt {} | tail -n 1" \;
答案 17 :(得分:0)
假设您不关心以.
ls -rt | tail -n 1
否则
ls -Art | tail -n 1
答案 18 :(得分:0)
所有这些ls / tail解决方案都可以很好地处理 目录中的文件 - 忽略子目录。
为了在搜索中包含所有文件(递归),可以使用find。 gioele建议对格式化的查找输出进行排序。但要注意空格(他的建议不适用于空格)。
这适用于所有文件名:
find $DIR -type f -printf "%T@ %p\n" | sort -n | sed -r 's/^[0-9.]+\s+//' | tail -n 1 | xargs -I{} ls -l "{}"
这是mtime的分类,见man find:
%Ak File's last access time in the format specified by k, which is either `@' or a directive for the C `strftime' function. The possible values for k are listed below; some of them might not be available on all systems, due to differences in `strftime' between systems.
@ seconds since Jan. 1, 1970, 00:00 GMT, with fractional part.
%Ck File's last status change time in the format specified by k, which is the same as for %A.
%Tk File's last modification time in the format specified by k, which is the same as for %A.
所以只需将%T
替换为%C
即可按ctime排序。
答案 19 :(得分:0)
ls -Frt | grep "[^/]$" | tail -n 1
答案 20 :(得分:-1)
我也需要这样做,我找到了这些命令。这些对我有用:
如果您希望在文件夹中创建日期的最后一个文件(访问时间):
ls -Aru | tail -n 1
如果您希望上一个文件的内容发生变化(修改时间):
ls -Art | tail -n 1