UNIX命令行参数引用问题
我试图告诉unix打印传递给Bourne Shell脚本的命令行参数,但它不起作用。我在echo语句中得到x的值,而不是在所需位置的命令行参数 这就是我想要的: /运行一个b c d a B C d 这就是我得到的: 一, 2. 3. 四, 发生什么事了?我知道,根据我在shell脚本中引用的内容(变量x或第x位置的命令行参数),UNIX很混乱。我如何才能澄清我的意思UNIX命令行参数引用问题,unix,command-line-arguments,sh,Unix,Command Line Arguments,Sh,我试图告诉unix打印传递给Bourne Shell脚本的命令行参数,但它不起作用。我在echo语句中得到x的值,而不是在所需位置的命令行参数 这就是我想要的: /运行一个b c d a B C d 这就是我得到的: 一, 2. 3. 四, 发生什么事了?我知道,根据我在shell脚本中引用的内容(变量x或第x位置的命令行参数),UNIX很混乱。我如何才能澄清我的意思 #!/bin/sh x=1 until [ $x -gt $# ] do echo $x x=`expr $x + 1` don
#!/bin/sh
x=1
until [ $x -gt $# ]
do
echo $x
x=`expr $x + 1`
done
编辑:谢谢大家的回答,但现在我有另一个问题;如果您不想从第一个参数开始计数,而是从第二个或第三个参数开始计数,该怎么办?那么,我该如何告诉UNIX从第二个位置开始处理元素,而忽略第一个位置呢
echo $*
$x不是第x个参数。它是变量x,expr$x+1
与其他语言中的x++类似
$x不是第x个参数。它是变量x,
expr$x+1
与其他语言中的x++类似。要使脚本按您的要求运行,最简单的更改如下:
#!/bin/sh
x=1
until [ $x -gt $# ]
do
eval "echo \${$x}"
x=`expr $x + 1`
done
然而(这是一个大问题),使用eval(尤其是在用户输入上)是一个巨大的安全问题。更好的方法是使用shift和第一个位置参数变量,如下所示:
#!/bin/sh
while [ $# -gt 0 ]; do
x=$1
shift
echo ${x}
done
要使脚本按您的要求运行,最简单的更改如下:
#!/bin/sh
x=1
until [ $x -gt $# ]
do
eval "echo \${$x}"
x=`expr $x + 1`
done
然而(这是一个大问题),使用eval(尤其是在用户输入上)是一个巨大的安全问题。更好的方法是使用shift和第一个位置参数变量,如下所示:
#!/bin/sh
while [ $# -gt 0 ]; do
x=$1
shift
echo ${x}
done
不使用
shift
的解决方案:
#!/bin/sh
for arg in "$@"; do
printf "%s " "$arg"
done
echo
不使用
shift
的解决方案:
#!/bin/sh
for arg in "$@"; do
printf "%s " "$arg"
done
echo
如果你想开始计算第二个参数
for i in ${@:2}
do
echo $i
done
如果你想开始计算第二个参数
for i in ${@:2}
do
echo $i
done
嗯…好的。但是如果我想在第二个参数开始打印呢?那么它不打印一个bcd,只打印一个bcd?嗯…好的。但是如果我想在第二个参数开始打印呢?那么它不打印一个bcd,只打印一个bcd?作为补充说明,如果你在使用函数,那么位置参数是函数参数,而不是程序参数。这很有用,但需要注意。另外,如果使用函数,则位置参数是函数参数,而不是程序参数。这很有用,但需要注意。