我编写了一个使用多个参数的 bash 脚本。 我已按以下格式分配了变量。
x=$1
y=$2
z=$3
k=$4
参数是可选的,没有它们也能运行 例如:
./myscript.sh
./myscript.sh x y ...
两种情况都工作正常。
从设计的角度来看,我正在寻找一种更好的方法,因为我不喜欢变量获取值的方式。
如果以后我的论据增加到 9 就不好看了
谢谢。
最佳答案
您可以使用 read
结合herestring和printf
的引用重构能力:
read x y z k <<<$(printf " %q" "$@")
举例:
$ cat example.bash
#!/bin/bash
read x y z k <<<$(printf " %q" "$@")
echo "x=[$x]"
echo "y=[$y]"
echo "z=[$z]"
echo "k=[$k]"
$ ./example.bash a b "c d"
x=[a]
y=[b]
z=[c d]
k=[]
那么,这里发生了什么?让我们由内而外地工作。
printf " %q" "$@"
quotes它以等同于原始命令行参数的方式给出的参数。如果没有这种引用重建,带空格的命令行参数将被视为单独的参数,即使最初被引用也是如此。要明白我的意思,试试 read x y z w <<<"$@"
: z 被分配为“c”,k 被分配为“d”。
read
接收重构的命令行,然后将每个非转义空格分隔的字符串从左到右分配给给定的变量。
回到我们的例子:
-
"$@"
本质上是a b "c d"
-
printf " %q" "$@"
是a b c\ d
-
read x y z k <<<"a b c\ d"
是您想要的硬编码表示。
虽然这是紧凑且可扩展的,但它也很棘手。如果您的脚本采用表示选项 的参数(脚本行为会根据是否存在所述参数而变化),那么我建议使用 getopts
.但是,如果您的脚本采用许多表示值 的参数(例如矩阵计算的输入),那么读入数组 (read -a
) 可能更容易理解。
您可能还想处理未提供命令行参数的情况。这需要稍微阐述一下:
read x y z k <<<$([ 0 -eq $# ] && echo '' || printf " %q" "$@")
在这个变体中,检查参数的数量,如果有,则执行 printf 重新引用业务。
关于linux - 以更好的方式分配变量值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40010240/