나는 bash 스크립트입니다 외면하였나니 함수가 포함되어 있는 쓸 때 '.tar 등의 tar 파일을 스타리그스 .tar.bz2', '', '함께' 관련 스위칭됩니다 파일 압축을 풀 사용한다.
지금 사용하고 있는 경우 그 내용을 볼 수 있는 it motor1.1end 엘리프 제표를 테스트하려면 파일_이름 일치시키려면 regex 를 사용하여 메타문자를 이해했소 수 없습니다.
test sed-4.2.2.tar.bz2 = tar\.bz2$; echo $?
(this returns 1, false)
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
}
이에 대해 권력을 주석문입니다 regex 를 저장하는 데 필요한 물병자리 위에서 우리는 var '
Bash_rematch 설정되었습니다 변수 $ {} 은 (는) [명사], 그리고 일치시키면 표현식에서는 bash_rematch 일치시킵니다 그룹화할 ie 에서 n = $ {} 괄호 안에 랩된 다음 'bash_rematch [1], [2]} = $ {bash_rematch " compressed"' 와 ',' .gz" ";
if [[ "compressed.gz" =~ ^(.*)(\.[a-z]{1,5})$ ]];
then
echo ${BASH_REMATCH[2]} ;
else
echo "Not proper format";
fi
(이 regex 그들위에 isn& # 39, t 제시하는 데 목적을 두고 있지만, 예를 들어 하나의 파일 명명 및 확장명으로 유효함 작동하잖아)
' [[sed-4.2.2.tar.bz2 = ~ tar.bz 2 달러]] & &; '에코 매칭됨
& # 39 은 실제로 일치시킵니다 아니라 모든 문자, 예를 들어 간 joyon. ipv6-literal. tar.bz2& # 39.
[[ sed-4.2.2.tar4bz2 =~ tar.bz2$ ]] && echo matched
[[ sed-4.2.2.tar§bz2 =~ tar.bz2$ ]] && echo matched
그러면 엄격한 구문을 수
[[ sed-4.2.2.tar.bz2 =~ tar\.bz2$ ]] && echo matched
또한 이전 점이 많다고 해도 포함시키십시오 regex 검색하기를 수도 있습니다.
[[ sed-4.2.2.tar.bz2 =~ \.tar\.bz2$ ]] && echo matched
배시 (bash 전날에약혼자에게 don& # 39 를 사용하고 있기 때문에, 이를 위한 프로세스 하위여야 만들 필요가 없다. 이것은 하나의 솔루션으로 이를 수행하는 내에 완전히 내주었다.
[[ $TEST =~ ^(.*):\ +(.*)$ ]] && TEST=${BASH_REMATCH[1]}:${BASH_REMATCH[2]}
설명: 이 전후에 그룹화합니다 e0100042.log " 콜론, 하나 이상의 spaces"; 패턴 (pattern) 에 저장되어 있는 작동자 일치시킵니다 bash_rematch 어레이입니다.