Estou tentando escrever um script bash que contém uma função, então quando dado um arquivo .tar',
.tar.bz2', `.tar.gz' etc. ele utiliza tar com as opções relevantes para descompactar o arquivo.
Eu estou usando se elif então declarações que testam o nome do arquivo para ver com o que ele termina e eu não consigo que ele corresponda usando os metacaracteres regex.
Para salvar constantemente reescrevendo o script que estou usando 'test' na linha de comando, eu achei que a declaração abaixo deveria funcionar, eu tentei todas as combinações de parênteses, citações e metacaraters possíveis e ainda assim falhou.
test sed-4.2.2.tar.bz2 = tar\.bz2$; echo $?
(this returns 1, false)
I'tenho certeza que o problema é simples e I'procurei em todos os lugares, mas não consigo entender como fazer isso. Alguém sabe como eu posso fazer isso?
Para combinar regexes você precisa utilizar o operador =~
.
Experimenta isto:
[[ sed-4.2.2.tar.bz2 =~ tar.bz2$ ]] && echo matched
Alternativamente, você pode utilizar wildcards (ao invés de regexes) com o operador ==
:
[[ sed-4.2.2.tar.bz2 == *tar.bz2 ]] && echo matched
Se a portabilidade não é uma preocupação, eu recomendo utilizar [[
em vez de [ou
test`, pois é mais seguro e mais poderoso. Veja [Qual é a diferença entre teste, [ e \ ?]1 para detalhes.
extract () {
if [ -f $1 ] ; then
case $1 in
*.tar.bz2) tar xvjf $1 ;;
*.tar.gz) tar xvzf $1 ;;
*.bz2) bunzip2 $1 ;;
*.rar) rar x $1 ;;
*.gz) gunzip $1 ;;
*.tar) tar xvf $1 ;;
*.tbz2) tar xvjf $1 ;;
*.tgz) tar xvzf $1 ;;
*.zip) unzip $1 ;;
*.Z) uncompress $1 ;;
*.7z) 7z x $1 ;;
*) echo "don't know '$1'..." ;;
esac
else
echo "'$1' is not a valid file!"
fi
}
Em resposta ao Aquarius Power no comentário acima, "Precisamos armazenar o regex em um var".
A variável BASH_REMATCH é definida depois de você corresponder à expressão, e ${BASH_REMATCH[n]} irá corresponder ao n-ésimo grupo envolto em parênteses, ou seja, no seguinte ${BASH_REMATCH[1]} = "compressed"
e ${BASH_REMATCH[2]} = ".gz"
if [[ "compressed.gz" =~ ^(.*)(\.[a-z]{1,5})$ ]];
then
echo ${BASH_REMATCH[2]} ;
else
echo "Not proper format";
fi
(O regex acima é't pretende ser um válido para nomear arquivos e extensões, mas funciona para o exemplo)