我需要创建一个包含使用 CSV 格式报告 (Output.rpt) 中的 ff 字段重命名的所有文件的报告。我需要一个显示的输出
a. Column1 = Original Filename
b. Column2 = Original Timestamp date
c. Column3 = Renamed filename value
下面是我使用原始文件名创建的 x 个文件的代码。
for i in {1938..2037}; do
## create a file with a random month
touch -d "${i}-$((RANDOM % 12 + 1))-01" file_$((i-1937))
done
Output is below:
-rw-r--r-- 0 Oct 1 2037 file_100
-rw-r--r-- 0 Jul 1 2036 file_99
-rw-r--r-- 0 Sep 1 2035 file_98
-rw-r--r-- 0 Jan 1 2034 file_97
下面是我用时间戳重命名文件的脚本
for f in *
do
ref=$(stat -c %y "$f" | awk '{print $1}')
mon=$(date -d "$ref" +%b)
year=$(date -d "$ref" +%Y)
mv -- "$f" "file_${mon^^}${year}"
done
Output:
-rw-r--r-- 0 Oct 1 2037 file_OCT2037
-rw-r--r-- 0 Jul 1 2036 file_JUL2036
-rw-r--r-- 0 Sep 1 2035 file_SEP2035
-rw-r--r-- 0 Jan 1 2034 file_JAN2034
答案1
对于实际重命名,请删除该echo
单词。
ls -l file_* |
awk '
BEGIN {
OFS=",";
print "Original filename", "Original timestamp", "Renamed filename" > "output.rpt";
}
{
renamed_filename = "file_" toupper($6) $8;
original_timestamp = sprintf("%d-%s-%02d", $8, $6, $7);
exit_status = system("echo mv -v -- " $9 " " renamed_filename);
if(!exit_status)
print $9, original_timestamp, renamed_filename > "output.rpt";
}'
原始文件
-rw-rw-r-- 1 user user 0 Jul 1 1938 file_1
-rw-rw-r-- 1 user user 0 Sep 1 1947 file_10
-rw-rw-r-- 1 user user 0 May 1 2037 file_100
生成的重命名命令
mv -v -- file_1 file_JUL1938
mv -v -- file_10 file_SEP1947
mv -v -- file_100 file_MAY2037
输出.rpt
### Comma-separated values.
$ cat output.rpt
Original filename,Original timestamp,Renamed filename
file_1,1938-Jul-01,file_JUL1938
file_10,1947-Sep-01,file_SEP1947
file_100,2037-May-01,file_MAY2037
### Pretty printed by the `column` command.
$ cat output.rpt | column -t -s,
Original filename Original timestamp Renamed filename
file_1 1938-Jul-01 file_JUL1938
file_10 1947-Sep-01 file_SEP1947
file_100 2037-May-01 file_MAY2037