$1是第一个参数。 $@是全部。
如何找到传递给shell的最后一个参数 脚本?
$1是第一个参数。 $@是全部。
如何找到传递给shell的最后一个参数 脚本?
当前回答
以下是我的解决方案:
相当可移植(所有POSIX sh, bash, ksh, zsh)应该工作 不移位原始参数(移位副本)。 不使用恶eval 不是遍历整个列表 不使用外部工具
代码:
ntharg() {
shift $1
printf '%s\n' "$1"
}
LAST_ARG=`ntharg $# "$@"`
其他回答
下面将在不改变当前环境的情况下将LAST设置为最后一个参数:
LAST=$({
shift $(($#-1))
echo $1
})
echo $LAST
如果其他参数不再需要并且可以被转移,则可以简化为:
shift $(($#-1))
echo $1
出于便携性的考虑:
shift $(($#-1));
可替换为:
shift `expr $# - 1`
同样用反引号替换$(),我们得到:
LAST=`{
shift \`expr $# - 1\`
echo $1
}`
echo $LAST
只需使用!$。
$ mkdir folder
$ cd !$ # will run: cd folder
美国小妞tcsh:
set X = `echo $* | awk -F " " '{print $NF}'`
somecommand "$X"
我很确定这将是一个可移植的解决方案,除了作业。
从最古老的解决方案到最新的解决方案:
最可移植的解决方案,甚至更老的sh(适用于空格和glob字符)(没有循环,更快):
eval printf "'%s\n'" "\"\${$#}\""
从bash 2.01版开始
$ set -- The quick brown fox jumps over the lazy dog
$ printf '%s\n' "${!#} ${@:(-1)} ${@: -1} ${@:~0} ${!#}"
dog dog dog dog dog
对于ksh, zsh和bash:
$ printf '%s\n' "${@: -1} ${@:~0}" # the space beetwen `:`
# and `-1` is a must.
dog dog
至于“倒数第二”:
$ printf '%s\n' "${@:~1:1}"
lazy
使用printf解决以破折号(如-n)开头的参数的任何问题。
对于所有shell和旧的sh(使用空格和glob字符)是:
$ set -- The quick brown fox jumps over the lazy dog "the * last argument"
$ eval printf "'%s\n'" "\"\${$#}\""
The last * argument
或者,如果你想设置最后一个变量:
$ eval last=\${$#}; printf '%s\n' "$last"
The last * argument
至于“倒数第二”:
$ eval printf "'%s\n'" "\"\${$(($#-1))}\""
dog
我发现@AgileZebra的答案(加上@starfry的评论)最有用,但它将头设置为一个标量。数组可能更有用:
heads=( "${@: 1: $# - 1}" )
tail=${@:${#@}}
注意,这是bash专用的。
编辑:根据@f-hauri的评论删除了不必要的$(())。