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