Как вырезать после позиции для конкретного символа в Unix

У меня есть имя файла как dat_cpoybook_tab1_tab2_tabnm.txt. Я хочу вырезать из таб1. т.е. мой вывод будет:

tab1_tab2_tabnm

Обратите внимание, что каждый раз, когда мне нужно обрезать его после двух '_' до '.txt'

2 ответа

echo "dat_cpoybook_tab1_tab2_tabnm.txt"|awk -F'.' '{print $1}'|awk -F'_' '{ARR[1]=$0;} 
END {
v1=match(ARR[1],"_");
s1=substr(ARR[1],v1+1);
v2=match(s1,"_"); 
print substr(s1,v2+1);       
}' 
grep -Po '([^_]+_){2}[^_]+(?=\.txt)'

kent$  echo "a_bx_c_d_e_f_g.txt"|grep -Po '([^_]+_){2}[^_]+(?=\.txt)' 
e_f_g

kent$  echo "dat_cpoybook_tab1_tab2_tabnm.txt"|grep -Po '([^_]+_){2}[^_]+(?=\.txt)'
tab1_tab2_tabnm

AWK:

awk -F'_|[.]txt' -v OFS="_" '$0=$(NF-3) OFS $(NF-2) OFS $(NF-1)'

kent$   echo "a_bx_c_d_e_f_g.txt"|awk -F'_|[.]txt' -v OFS="_" '$0=$(NF-3) OFS $(NF-2) OFS $(NF-1)'                                                                          
e_f_g
Другие вопросы по тегам