# Shell中的变量
# 系统变量
- 常用系统变量
$HOME、$PWD、$SHELL、$USER等
- 案例实操
(1)查看系统变量的值
[bigdata@hadoop01 ~]$ echo $HOME
/home/bigdata
[bigdata@hadoop01 ~]$ echo $PWD
/home/bigdata
[bigdata@hadoop01 ~]$ echo $SHELL
/bin/bash
[bigdata@hadoop01 ~]$ echo $USER
bigdata
2
3
4
5
6
7
8
(2)显示当前Shell中所有变量:set
[bigdata@hadoop01 ~]$ set
BASH=/bin/bash
BASHOPTS=checkwinsize:cmdhist:expand_aliases:extquote:force_fignore:histappend:hostcomplete:interactive_comments:login_shell:progcomp:promptvars:sourcepath
BASH_ALIASES=()
BASH_ARGC=()
BASH_ARGV=()
BASH_CMDS=()
BASH_LINENO=()
BASH_SOURCE=()
BASH_VERSINFO=([0]="4" [1]="2" [2]="46" [3]="2" [4]="release" [5]="x86_64-redhat-linux-gnu")
BASH_VERSION='4.2.46(2)-release'
COLUMNS=105
DIRSTACK=()
EUID=1008
...
2
3
4
5
6
7
8
9
10
11
12
13
14
15
# 自定义变量
1.基本语法
(1)定义变量:变量=值
(2)撤销变量:unset 变量
(3)声明静态变量:readonly 变量
,注意:不能unset
2.变量定义规则
(1)变量名称可以由字母、数字和下划线组成,但是不能以数字开头,环境变量名建议大写。
(2)等号两侧不能有空格
(3)在bash中,变量默认类型都是字符串类型,无法直接进行数值运算。
(4)变量的值如果有空格,需要使用双引号或单引号括起来。
3.案例实操
(1)定义变量A
[bigdata@hadoop01 ~]$ A=10
[bigdata@hadoop01 ~]$ echo $A
10
2
3
(2)给变量A重新赋值
[bigdata@hadoop01 ~]$ A=12
[bigdata@hadoop01 ~]$ echo $A
12
2
3
(3)撤销变量A
[bigdata@hadoop01 ~]$ unset A
[bigdata@hadoop01 ~]$ echo $A
2
3
(4)声明静态的变量B=2,不能unset
[bigdata@hadoop01 ~]$ readonly B=2
[bigdata@hadoop01 ~]$ unset B
-bash: unset: B: 无法反设定: 只读 variable
2
3
(5)在bash中,变量默认类型都是字符串类型,无法直接进行数值运算
[bigdata@hadoop01 ~]$ C=1+1
[bigdata@hadoop01 ~]$ echo $C
1+1
2
3
(6)变量的值如果有空格,需要使用双引号或单引号括起来
[bigdata@hadoop01 ~]$ LL= I LOVE HMM
-bash: I: 未找到命令
[bigdata@hadoop01 ~]$ LL='I LOVE HMM'
[bigdata@hadoop01 ~]$ echo $LL
I LOVE HMM
2
3
4
5
(7)可把变量提升为全局环境变量,可供其他Shell程序使用
export 变量名
在helloworld.sh文件中增加echo $LL:
[bigdata@hadoop01 datas]$ vim helloworld.sh
#!/bin/bash
echo "hello world bigdata"
echo $LL
2
3
4
5
发现并没有打印输出变量LL的值:
[bigdata@hadoop01 datas]$ echo $LL
I LOVE HMM
[bigdata@hadoop01 datas]$ ./helloworld.sh
hello world bigdata
# 把LL提升为全局变量
[bigdata@hadoop01 datas]$ export LL
[bigdata@hadoop01 datas]$ ./helloworld.sh
hello world bigdata
I LOVE HMM
2
3
4
5
6
7
8
9
10
# 特殊变量:$n
1.基本语法
$n
(功能描述:n
为数字,$0
代表该脚本名称,$1-$9
代表第一到第九个参数,十以上的参数,十以上的参数需要用大括号包含,如${10}
)
2.案例实操
输出该脚本文件名称、输入参数1和输入参数2 的值
[bigdata@hadoop01 datas]$ vim parameter.sh
#!/bin/bash
echo "$0 $1 $2 $3"
[bigdata@hadoop01 datas]$ bash parameter.sh
parameter.sh #$0:代表该脚本名称
[bigdata@hadoop01 datas]$ bash parameter.sh limi
parameter.sh limi
[bigdata@hadoop01 datas]$ bash parameter.sh limi love
parameter.sh limi love
[bigdata@hadoop01 datas]$ bash parameter.sh limi love hamey
parameter.sh limi love hamey
[bigdata@hadoop01 datas]$ bash parameter.sh limi love hamey haha
parameter.sh limi love hamey
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
# 特殊变量:$#
1.基本语法
$#
(功能描述:获取所有输入参数个数,常用于循环)。
2.案例实操
获取输入参数的个数
[bigdata@hadoop01 datas]$ vim parameter.sh
#!/bin/bash
echo "$0 $1 $2 $3"
echo $# #增加这一行
[bigdata@hadoop01 datas]$ bash parameter.sh
parameter.sh
0
[bigdata@hadoop01 datas]$ bash parameter.sh limi
parameter.sh limi
1
[bigdata@hadoop01 datas]$ bash parameter.sh limi love
parameter.sh limi love
2
[bigdata@hadoop01 datas]$ bash parameter.sh limi love hamey
parameter.sh limi love hamey
3
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
# 特殊变量:$*
、$@
1.基本语法
$*
(功能描述:这个变量代表命令行中所有的参数,$*
把所有的参数看成一个整体)
$@
(功能描述:这个变量也代表命令行中所有的参数,不过$@
把每个参数区分对待)
2.案例实操
打印输入的所有参数
[bigdata@hadoop01 datas]$ vim parameter.sh
#!/bin/bash
echo "$0 $1 $2 $3"
echo $#
echo $* #增加这一行
echo $@ #增加这一行
[bigdata@hadoop01 datas]$ bash parameter.sh limi love hamey
parameter.sh limi love hamey #$0 $1 $2 $3
3 #$#获取所有输入参数个数
limi love hamey #$*代表命令行中所有的参数
limi love hamey #$@代表命令行中所有的参数
2
3
4
5
6
7
8
9
10
11
12
13
14
15
# 特殊变量:$?
1.基本语法
$?
(功能描述:最后一次执行的命令的返回状态。如果这个变量的值为0,证明上一个命令正确执行;如果这个变量的值为非0(具体是哪个数,由命令自己来决定),则证明上一个命令执行不正确了。)
2.案例实操
判断helloworld.sh脚本是否正确执行
[bigdata@hadoop01 datas]$ ./helloworld.sh
hello world bigdata
[bigdata@hadoop01 datas]$ $?
-bash: 0: 未找到命令
[bigdata@hadoop01 datas]$ echo $?
127
[bigdata@hadoop01 datas]$ ./helloworld.sh
hello world bigdata
[bigdata@hadoop01 datas]$ echo $?
0
2
3
4
5
6
7
8
9
10
11
12