我有一個 Linux 命令串列,我需要重復最多 670 次。我怎樣才能自動化這些命令,所以我不必重復 670 次。我不知道從C1、C2、C3 ....到C670的所有操作怎么辦?
#START C1
mkdir C1
cd C1
awk '/Prymnesium_parvum_GenomeV1.0_Contig_1\t/' ../Methy_670.txt | cut -f 2 > IllU_C1.txt
awk '/Prymnesium_parvum_GenomeV1.0_Contig_1\t/' ../TE/TEannotation_Prymnesium_parvum_GenomeV1.0.gff3 | cut -f 4,5 > TE_C1.txt
paste TE_C1.txt IllU_C1.txt> C1.txt
awk -f ../com.awk C1.txt C1.txt > res_C1
wc -l res_C1
wc -l TE_C1.txt
cd ..
###Stop C1
#Start C2
mkdir C2
cd C2
awk '/Prymnesium_parvum_GenomeV1.0_Contig_2\t/' ../Methy_670.txt | cut -f 2 > IllU_C1.txt
awk '/Prymnesium_parvum_GenomeV1.0_Contig_2\t/' ../TE/TEannotation_Prymnesium_parvum_GenomeV1.0.gff3 | cut -f 4,5 > TE_C1.txt
....
uj5u.com熱心網友回復:
未測驗:
#!/bin/bash
for C in {1..670};do
echo START ${C}
mkdir -p ${C} && cd ${C}
awk '/Prymnesium_parvum_GenomeV1.0_Contig_'${C}'\t/' ../Methy_670.txt | cut -f 2 > IllU_${C}.txt
awk '/Prymnesium_parvum_GenomeV1.0_Contig_'${C}'\t/' ../TE/TEannotation_Prymnesium_parvum_GenomeV1.0.gff3 | cut -f 4,5 > TE_${C}.txt
paste TE_${C}.txt IllU_${C}.txt> ${C}.txt
awk -f ../com.awk ${C}.txt ${C}.txt > res_${C}
wc -l res_${C}
wc -l TE_${C}.txt
cd ..
echo Stop ${C}
done
我不確定是什么awk '/Prymnesium_parvum_GenomeV1.0_Contig_1\t/' ../Methy_670.txt,但您必須弄清楚如何在其中添加 ${C} ,因為單引號不會決議${C}
uj5u.com熱心網友回復:
另一種看法:awk 可以做 cut 做的事情
#!/usr/bin/env bash
prep_dir() {
local n=$1
local c=C$n ill=IllU_$c.txt te=TE_$c.txt
local pattern="Prymnesium_parvum_GenomeV1.0_Contig_${n}\t"
if mkdir "$c" && cd "$c"; then
awk -v p="$pattern" '$0 ~ p {print $2}' ../Methy_670.txt > "$ill"
awk -v p="$pattern" '$0 ~ p {print $4, $5}' ../TE/TEannotation_Prymnesium_parvum_GenomeV1.0.gff3 > "$te"
paste "$te" "$ill" > "$c.txt"
awk -f ../com.awk "$c.txt" "$c.txt" > "res_$c"
wc -l "res_$c"
wc -l "$te"
cd ..
fi
}
for i in {1..670}; do
prep_dir $i
done
轉載請註明出處,本文鏈接:https://www.uj5u.com/net/474227.html
