『忘了再学』Shell基础 — 16、位置参数变量

位置參数变量的作用主要用于脚本的传参。

位置參数变量的名称和作用都是确定不能改变的,但是该变量的内容是可以更改的,也就是变量的值。

位置參数变量如下:

位置参数变量 作用
$n n为数字,$0代表命令本身,$1-$9代表(脚本命令后的)第一到第九个参数,十以上的参数需要用大括号包含,如${10}${15}
$* 这个变量代表命令行中所有的参数,$*把所有的参数看成一个整体。
$@ 这个变量也代表命令行中所有的参数,不过$@把每个参数区分对待。
$# 这个变量代表命令行中所有参数的个数。

1、位置参数变量$n

$nn为数字,$0代表命令本身,$1-$9代表(脚本命令的)第一到第九个参数,十以上的参数需要用大括号包含,如${10}${15}。(这个是一个典型的向Shell脚本当中传递值的方式)

(1)示例:

# 定义一个shell脚本,简单的计算器,求两个数的和。

[root@Lyl tmp]# vim count.sh

# 脚本内容如下:

#!/bin/bash

# 给num1变量赋值是第一个参数
num1=$1
# 给num2变量赋值是第二个参数
num2=$2

# 变量sum是变量num1加变量num2的(其实上边的num1和num2的定义可以省略)
sum=$(($num1 + $num2))
# 注意:执行count.sh脚本后的第一个参数会传递给$1,第二个参数会传递给$2,
# 然后$num1和$num2进行求和,再赋值给sum变量。
# 但是Shell中自定义变量的默认类型是字符串类型,
# 而我们传入的两个数字类型的变量值,Shell默认都识别为字符串类型。
# 而这个时候我们就需要$(( ))把这个两个字符串类型的数值括起来,
# Shell才能知道要进行数值运算,里边的参数都是数值(Shell运算符中会详细讲)。
# 而$( )是括系统命令的,然后把该命令运行的结果,赋值给前面的变量,这个我们要注意。


#打印变量sum的值
echo $sum
echo $0

# 执行该脚本
[root@Lyl tmp]# chmod 755 count.sh
[root@Lyl tmp]# ./count.sh 22 66
88
./count.sh

(2)总结:

  • $1保存的是执行Shell命令之后的第一个参数,
  • $2保存的是执行Shell命令之后的第二个参数,
  • $0代表执行脚本的命令,如上边的./count.sh
  • 位置參数变量好处。
    其作用就是把执行脚本命令后输入的参数,传入到脚本中,使脚本中的变量可以灵活取值。
  • 位置參数变量的缺点。
    如果是一个普通的Linux用户,该脚本并不是自己写的。当你获得该脚本的时候,你是无法知道需要在脚本后边是否加参数,或者是加什么参数,脚本才能正确运行,是没有任何提示的。
    所以用位置參数变量传参,并不适合给普通用户来使用,一般是写的脚本自己用的时候,用的比较多。

提示:

位置參数变量也可以给函数中传参(其实就是自己给自己传值)。

给普通用户的脚本,传参的方式用read,会有提示,比较友好,我们之后说明。

2、位置参数变量$*$@

$*:这个变量代表命令行中所有的参数,$*把所有的参数看成一个整体。

$@:这个变量也代表命令行中所有的参数,不过$@把每个参数区分对待。

(1)用法

我们先写一个脚本来展示一下位置参数变量$*$@的用法:

# 定义一个脚本parameter.sh

[root@Lyl tmp]# vim parameter.sh


# 脚本内容如下:

#!/bin/bash

# 使用$*代表所有的参数(所有参数整体对待)
echo "The parameters \$* is:$*"
# 使用也代表所有参数(所有参数分开对待)
echo "The parameters \$@ is:$@"



# 执行该脚本
[root@Lyl tmp]# chmod 755 parameter.sh 
[root@Lyl tmp]# ./parameter.sh 11 22 33 44
The parameters $* is:11 22 33 44
The parameters $@ is:11 22 33 44

我们可以看到位置参数变量$*$@,都把执行脚本命令后边带的参数打印出来了。

(2)区别

位置参数变量$\*$@的区别是,$*把所有参数当作一个整体,而$@是先把11赋值给$@,在把22赋值给$@,以此类推,是分开的。

我们通过下边的例子来说明:

# 我们先简单的来说一下for循环
# 简单的for循环例子

for i in 1 2 3 4
        do
            echo $i
        done

# 说明:
# 在in后有几个数或者说是以空格隔开的变量(因为默认都是字符串类型),
# in后有几个变量,这个for循环就循环几次。
# 第一次循环,把第一个变量赋值给in前边的变量i,然后进入循环操作。
# 这只是for循环的一种形式,知道流程即可,后边会在详细说明Bash中的for循环。
# do和done就类似于Java中for循环的大括号(先这样理解就可以)。


# 写一个for循环脚本
[root@Lyl tmp]# vim for.sh


# 脚本内容如下:

#!/bin/bash
for i in 1 2 3 4
    do
        echo $i
    done

# 执行该脚本
[root@Lyl tmp]# chmod 755 for.sh
[root@Lyl tmp]# ./for.sh
1
2
3
4

示例区别:

# 定义一个脚本param.sh
[root@Lyl tmp]# vim param.sh


# 脚本内容如下:

#!/bin/bash

# 定义for循环,in后面有几个值,for会循环多少次,
# 注意"S*"要用双引号括起来,每次循环会把in后面的值赋予变量i,
# Shell把$*中的所有参数看成是一个整体,所以这个for循环只会循环一次。

for i in "$*"
    do
        # 打印变量i的值
        echo "循环了"$i
    done

echo "==============="

# Shell把$@中的每个参数都看成是独立的,所以“$@"中有几个参数,就会循环几次。
# 注意两个for循环的变量名最好不相同,以示区别。相同也没关系。
for j in "$@"
    do
        # 打印变量j的值
        echo "循环了"$j
    done


# 执行该脚本
[root@Lyl tmp]# chmod 755 param.sh
[root@Lyl tmp]# ./param.sh 11 22 33 44
循环了11 22 33 44
===============
循环了11
循环了22
循环了33
循环了44

图示:

image

3、位置参数变量$#

$#:这个变量代表命令行中所有参数的个数。

示例:

# 定义一个脚本parameter.sh

[root@Lyl tmp]# vim parameter.sh


# 脚本内容如下:

#!/bin/bash

# 使用$#代表所有参数的个数
echo "The parameters \$# is:$#"


# 执行该脚本
[root@Lyl tmp]# chmod 755 parameter.sh
[root@Lyl tmp]# ./parameter.sh 11 22 33 44
The parameters $# is:4

posted @ 2022-05-23 11:01  繁华似锦Fighting  阅读(522)  评论(0编辑  收藏  举报