И другой способ сделать это, если Ваша находка не поддерживает printf
find . -type f | xargs ls -al | awk -v pwd="$PWD" '{ print $(NF-2), $(NF-1) , pwd substr($(NF), 2)}'
Примечание: Это только работает, пока нет никаких пробелов в именах файлов. Вывод похож на это:
2010-09-29 22:08 /home/nifle/ac.txt
2010-10-04 16:02 /home/nifle/array.sh
2010-10-05 23:32 /home/nifle/b.txt
2010-12-15 16:49 /home/nifle/barcopy/subbar/ghut
2010-12-15 16:48 /home/nifle/bardir/subbar/ghut
2010-09-29 22:16 /home/nifle/foo.gz
2010-09-29 22:16 /home/nifle/foo1.gz
Выполненный ls
на каждом файле и фильтре результат:
find "$PWD" -type f -exec ls -la {} \; | cut -d ' ' -f 6-
Вывод:
Jun 14 00:02 /tmp/superuser.com/questions/370070/bar
Jun 14 20:24 /tmp/superuser.com/questions/228529/file with multiple spaces
Jan 2 1972 /tmp/superuser.com/questions/228529/old_file
Использовать -printf
:
find "$PWD" -type f -printf "%t %p\n"
Вывод:
Thu Jun 14 00:02:47.0173429319 2012 /tmp/superuser.com/questions/370070/bar
Thu Jun 14 20:24:16.0947808489 2012 /tmp/superuser.com/questions/228529/file with multiple spaces
Sun Jan 2 03:04:05.0000000000 1972 /tmp/superuser.com/questions/228529/old_file
Выполните GNU stat
на каждом файле:
find "$PWD" -type f -exec stat --format '%y %n' {} \;
Вывод:
2016-03-30 04:32:10.034718786 +0300 /etc/passwd
2015-12-21 19:30:07.854470768 +0200 /etc/group
Подсказка: если у Вас есть GNU, находят, \;
может быть заменен \+
.