Supondo que o exemplo que você fornece reflete todos os seus arquivos, o seguinte deve ser o truque:
for f in *.1.dat
do
cat ${f%%1.dat}* > ${f%%1.dat}1_3.dat
done
Isso requer que cada grupo contenha um arquivo com a extensão .1.dat.
Eu tenho arquivos com a convenção de nomenclatura desse padrão:
bond_7.LEU.CA.1.dat
bond_7.LEU.CA.2.dat
bond_7.LEU.CA.3.dat
bond_12.ALA.CB.1.dat
bond_12.ALA.CB.2.dat
bond_12.ALA.CB.3.dat
...
Eu quero concatenar todos os arquivos do mesmo grupo em um único. Por exemplo:
cat bond_7.LEU.CA.*.dat > ../bondvalues/bond_7.LEU.CA.1_3.dat
Existe um grande número desses arquivos. Como pode conseguir isso com um script bash?
Supondo que o exemplo que você fornece reflete todos os seus arquivos, o seguinte deve ser o truque:
for f in *.1.dat
do
cat ${f%%1.dat}* > ${f%%1.dat}1_3.dat
done
Isso requer que cada grupo contenha um arquivo com a extensão .1.dat.
printf "%s\n" * | cut -d. -f1-3 | sort -u | while read prefix; do
files=(${prefix}*)
first=$(cut -d. -f4 <<< "${files[0]}")
last=$(cut -d. -f4 <<< "${files[${#files[@]}-1]}")
newfile=$(printf "../bondvalues/%s.%s_%s.dat" "$prefix" "$first" "$last")
cat "${files[@]}" > "$newfile"
done
Tags bash-scripting