関連:csvリストに基づいて、一致するプレフィックスを持つすべてのファイルをフォルダに移動します。
ヘッダーを含む2つの列CSVファイル(カンマ区切り値)があります。
"id","group"
"F1256","old"
"E51651","new"
"X56369","new"
"G5481369","old"
"54564564T","old"
"544-5F5","new"
"1298FFF","old"
"JKL-wew_w","new"
これらのファイルをディレクトリに入れました。
2014-12-15_T921_F1256.png
E51651_hf_2018-9-19.jpg
hf_oldX56369_15-10-2014.xml
2018-07_xx54564564T_hfdata.bmp
G5481369oldbackup_2018-01-01.txt
grep
このファイルに(または他の同様のツール)を使用し、そのファイル名を私のid
CSVファイルの列と一致させたいと思います。一致するものがある場合(つまり、id
ファイル名で正確に見つかった場合)、そのファイルを適切なgroup
サブディレクトリに移動する必要があります。
したがって、現在のディレクトリに2つのフォルダを作成する必要がありold
、new
これらのファイルはすべて説明されている条件に従って移動する必要があります。
結果
old
├──2014-12-15_T921_F1256.png
├──2018-07_xx54564564T_hfdata.bmp
├──G5481369oldbackup_2018-01-01.txt
new
├──E51651_hf_2018-9-19.jpg
├──hf_oldX56369_15-10-2014.xml
どうすればいいですか?
答え1
解決策は次awk
のとおりです。
awk -F, 'NR>1 { group[$2]= group[$2]? group[$2] "* *" $1: $1 ;next }
END {
for (x in group) printf( "echo mv *%s* -t %s\n" , group[x], x )
}' infile.csv| sh
echo
結果が満足であれば削除してください。
.
├── infile.csv
├── new
│ ├── E51651_hf_2018-9-19.jpg
│ └── hf_oldX56369_15-10-2014.xml
└── old
├── 2014-12-15_T921_F1256.png
├── 2018-07_xx54564564T_hfdata.bmp
└── G5481369oldbackup_2018-01-01.txt
これにより、そのディレクトリグループに属するすべてのファイルがすぐに移動されます。説明
については、awk
以下を参照してください。私の最近の答え。
答え2
まず、sed n xargsでこれを行うことができます。
sed -e '
s/","/* /;s/^"/*/;s/"$//;1d
' | xargs -l sh -c 'mv $1 "$2"' _
注:引用符、スペースなど、xargsパイプを使用するときに注意する必要があるすべての注意事項は次のとおりです。
答え3
Pythonでは:
import csv, os, glob
filenames = []
filedir = 'files'
with open('filelist.csv', 'rb') as f:
reader = csv.reader(f)
filelist = list(reader)
filelist.pop(0)
for k, filename in enumerate(glob.glob(filedir + '/*')):
filenames.append(os.path.basename(filename))
for (id, directory) in filelist:
matches = [e for e in filenames if id in e]
for (filename) in matches:
if not os.path.exists(directory):
os.makedirs(directory)
os.rename(filedir + '/' + filename, directory + '/' + filename)
答え4
この試み:
#!/bin/bash
input_file="$1"
base_dir="$2"
delim=","
while read -r line
do
id=${line%$delim*}
group=${line#*$delim}
mv *"${id}"* "$base_dir//$group"
done < "$input_file"
このサンプルプロセス入力ファイルには定義(最初の)行は含まれておらず、IDとグループは引用されません。