回答:
ls -Art | tail -n 1
エレガントではありませんが、機能します。
ls
toのすべての出力をパイプ処理しtail
、最後の行のみを出力します。私見ではhead
、chaos
推奨されているように、昇順でソートして代わりに使用することをお勧めします。最初の行のヘッドの印刷が終了すると、次の行(実際には次のブロック)を送信するとSIGPIPEが発生し、ls
同様に終了します。
ls -t | head -n1
このコマンドは、実際には現在の作業ディレクトリにある変更された最新のファイルを提供します。
ls -tl | head -n 1
私のようにパイプ全体をテーブル全体にプッシュする必要はありません。
ls -t *.png | head -n1
ls -Art | head -n1
ます。特に、最後に変更されたファイルが必要な場合
これは再帰的なバージョンです(つまり、特定のディレクトリまたはそのサブディレクトリのいずれかで最近更新されたファイルを見つけます)
find $DIR -type f -printf "%T@ %p\n" | sort -n | cut -d' ' -f 2- | tail -n 1
編集:使用-f 2-
の代わりに、-f 2
ケビンにより示唆されるように
find $DIR -type f -exec stat -lt "%Y-%m-%d" {} \+ | cut -d' ' -f6- | sort -n | tail -1
sort -nr
使用して効率をわずかに向上させることができます。(ただし、再帰的検索をソートする場合、最初または最後の行を取得することは遅い部分ではありません。)head -n 1
tail -n 1
find ./ -type f -printf "%T@ %p\n" -ls | sort -n | cut -d' ' -f 2- | tail -n 1 | xargs -r ls -lah
find $DIR -type f -exec stat -lt "%F %T" {} \+ | cut -d' ' -f6- | sort -n | tail -1
信頼性に関する注意:
改行文字はファイル名と同様に有効であるため、/ ベースの行などの行に依存するソリューションには問題があります。head
tail
GNU ls
では、もう1つのオプションは、--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
この面倒な作業をすべて回避する代わりに、そのglob修飾子を使用することです。
現在のディレクトリにある最新の通常ファイル:
printf '%s\n' *(.om[1])
非表示のものを含む:
printf '%s\n' *(D.om[1])
2番目に新しい:
printf '%s\n' *(.om[2])
symlink解決後にファイルの経過時間を確認します。
printf '%s\n' *(-.om[1])
再帰的に:
printf '%s\n' **/*(.om[1])
また、補完システム(compinit
およびco)を有効にCtrl+Xmすると、最新のファイルに展開する補完機能になります。
そう:
vi Ctrl+Xm
最新のファイルを編集します(を押す前に、それを確認することもできますReturn)。
vi Alt+2Ctrl+Xm
2番目に新しいファイル。
vi * .cCtrl+Xm
最新のc
ファイル。
vi *(。)Ctrl+Xm
最新の通常のファイル(ディレクトリやfifo / device ...ではない)など。
zsh
ヒントをありがとう。これに関する詳細へのリンクをzsh docsに提供できますか?
info zsh qualifiers
私が使う:
ls -ABrt1 --group-directories-first | tail -n1
フォルダーを除いて、ファイル名だけが表示されます。
ls -lAtr | tail -1
他のソリューションには、で始まるファイルは含まれていません'.'
。
このコマンドには'.'
and も含まれます'..'
。これは、必要な場合とそうでない場合があります。
ls -latr | tail -1
私はecho *(om[1])
(zsh
構文)が好き です。ファイル名を指定するだけで、他のコマンドは呼び出されません。
個人的には、組み込みでないbash
コマンドをできる限り少なく使用することを好みます(高価なforkおよびexec syscallの数を減らすため)。日付でソートするには、ls
呼び出す必要があります。しかし、の使用head
は本当に必要ではありません。次のワンライナーを使用しています(名前パイプをサポートするシステムでのみ機能します)。
read newest < <(ls -t *.log)
または最も古いファイルの名前を取得する
read oldest < <(ls -rt *.log)
(2つの '<'マークの間のスペースに注意してください!)
隠しファイルも必要な場合-argを追加できます。
これがお役に立てば幸いです。
ls -t -1 | sed '1q'
フォルダ内の最後に変更されたアイテムを表示します。とペアリングしgrep
て、キーワードを持つ最新のエントリを検索します
ls -t -1 | grep foo | sed '1q'
1
最初の行head -n 1
はqと同じですか?
この簡単なコマンドを試してください
ls -ltq <path> | head -n 1
ファイル名が必要な場合-最終変更、パス= /ab/cd/*.log
ディレクトリ名が必要な場合-最終変更、パス= / ab / cd / * /
で始まる隠しファイルを気にしないと仮定します .
ls -rt | tail -n 1
さもないと
ls -Art | tail -n 1
唯一バッシュビルトイン、密接以下とBashFAQ / 003:
shopt -s nullglob
for f in * .*; do
[[ -d $f ]] && continue
[[ $f -nt $latest ]] && latest=$f
done
printf '%s\n' "$latest"
これらの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でソートされます。manfindを参照してください。
%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でソートします。
find $DIR -type f -printf "%T@ %p\n" | sort -n | cut -d' ' -f 2- | tail -n 1
または、最初のフィールドを除いてすべて保持: find $DIR -type f -printf "%T@ %p\n" | sort -n | cut -d' ' -f 1 --complement | tail -n 1
ls -Frt | grep "[^/]$" | tail -n 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
変更されたファイルではなく同じことをしたいが、アクセスされたファイルに対しては、単純に変更する必要があります
statコマンドから%Xへの%Yパラメータ。そして、最近アクセスしたファイルに対するコマンドは次のようになります。
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
両方のコマンドで、1つ以上のファイルを一覧表示する場合は、var = "1"パラメータを変更することもできます。
私もそれをする必要があり、これらのコマンドを見つけました。これらは私のために働きます:
フォルダ(アクセス時間)内の作成日で最後のファイルが必要な場合:
ls -Aru | tail -n 1
そして、内容が変更された最後のファイルが必要な場合(時間を変更):
ls -Art | tail -n 1
watch -n1 'ls -Art | tail -n 1'
-最後のファイルを表示します