名前があります。
患者サンプル_L001_R1_001、患者サンプル_L002_R1_001、患者サンプル_L003_R1_001、患者サンプル_L004_R1_001
名前の異なるグループ
患者サンプル_L001_R1_002、患者サンプル_L002_R1_002、患者サンプル_L003_R1_002、患者サンプル_L004_R1_002、
その他 4 つのファイルで構成される各セット (他のエンド番号 001,002,003) について、 Patient0001 または Patient 0002 などというラベルの付いた適切なディレクトリに移動する必要があります。私はこのセットを約200個持っています。エンド番号の異なるファイルをスキャンして適切な患者フォルダに配置するコマンドはありますか?
つまり、Patient_sample_L001_R1_001、Patient_sample_L002_R1_001、Patient_sample_L003_R1_001、Patient_sample_L004_R1_001、「患者0001フォルダなど」に入ります。
各ファイルは異なるディレクトリにあります。たとえば、ホームディレクトリには、患者1のデータを含むrun40というディレクトリがあります。その後、run41には患者2データなどがあります。デフォルトのディレクトリに戻ると、「total_patent_samples」という別のディレクトリがあります。ここでは、「run40、run41」ディレクトリからファイルを移動したいすべてのディレクトリを見つけることができます。このファイルには、患者0001、患者0002、患者0003があります。上記のデータファイルをここに入れたいです。
答え1
どうですか?
for i in `seq -f '%03g' 1 200`; do
FOLDER=patient0$i
mkdir -p total_patient_samples/$FOLDER # creates folder if missing
find . -regex ".*patient_sample_L00._R._${i}$" -type f -exec mv -i {} total_patient_samples/$FOLDER/ \; # moves patient data if not already there, else prompts
done
この操作をi
001から200まで繰り返し(必要に応じて200変更)、患者フォルダを作成し(mkdir ...
必要でない場合は行を削除)、指定した構造内のすべての患者を見つけてフォルダに移動します。
答え2
次のことができます。
cd total_patient_samples
find ../ -name patient_sample_\* | while read -r i; do
pnum="${i##*_}"
mkdir -p "patient$pnum"
mv -v "$i" "patient$pnum"
done
ファイルの正確な名前によって多くの部分が異なりますので、注意してください。
編集:以下のコメントに基づいてコードを更新しました。これにより、ホームディレクトリから一致するファイルがすべてインポートされますので、patient_sample_*
移動したくないファイルがないことを確認してください。
答え3
次のことができます。
for file in patient*; do
PATIENT_NO=$(echo $file | sed 's/patient_sample_.*R1_\(.*\)/\1/')
PATIENT_DIR=patient$PATIENT_NO
mkdir -p $PATIENT_DIR
mv $file $PATIENT_DIR
done
まず、患者番号を切り取り、ディレクトリ名をsed
作成し、ファイルをそのディレクトリに移動します。