正如标题所说,我正在寻找一种方法来删除变量开头和结尾的定义模式。我知道我必须使用#
,%
但我不知道正确的语法。
在这种情况下,我想http://
在从./score/
$line
file.txt
好吧,你不能嵌套${var%}
/${var#}
操作,所以你必须使用临时变量。
像这儿:
var="http://whatever/score/"
temp_var="${var#http://}"
echo "${temp_var%/score/}"
或者,您可以将正则表达式与(例如)sed 一起使用:
some_variable="$( echo "$var" | sed -e 's#^http://##; s#/score/$##' )"
$ var='https://www.google.com/keep/score'
$ var=${var#*//} #removes stuff upto // from begining
$ var=${var%/*} #removes stuff from / all the way to end
$ echo $var
www.google.com/keep
您必须分两步完成:
$ string="fooSTUFFfoo"
$ string="${string%foo}"
$ string="${string#foo}"
$ echo "$string"
STUFF
有一种方法可以仅使用内置的 bash 功能(不运行外部程序,例如sed
)来一步完成——使用BASH_REMATCH
:
url=http://whatever/score/
re='https?://(.*)/score/'
[[ $url =~ $re ]] && printf '%s\n' "${BASH_REMATCH[1]}"
这与测试右侧的正则表达式匹配=~
,并将组放入BASH_REMATCH
数组中。
也就是说,使用两个 PE 表达式和一个临时变量更为传统:
shopt -s extglob
url=http://whatever/score/
val=${url#http?(s)://}; val=${val%/score/}
printf '%s\n' "$val"
...在上面的示例中,该extglob
选项用于允许 shell 识别“extglobs”——bash 对 glob 语法的扩展(使 glob 样式的模式在功能上类似于正则表达式),其中?(foo)
意味着这foo
是可选的。
顺便说一句,我使用printf
而不是echo
在这些示例中是因为echo
' 的许多行为是实现定义的——例如,考虑变量内容为-e
或的情况-n
。
怎么样
export x='https://www.google.com/keep/score';
var=$(perl -e 'if ( $ENV{x} =~ /(https:\/\/)(.+)(\/score)/ ) { print qq($2);}')