# Shell中的变量

# 系统变量

  1. 常用系统变量
$HOME$PWD$SHELL$USER
1
  1. 案例实操

(1)查看系统变量的值

[bigdata@hadoop01 ~]$ echo $HOME
/home/bigdata
[bigdata@hadoop01 ~]$ echo $PWD
/home/bigdata
[bigdata@hadoop01 ~]$ echo $SHELL
/bin/bash
[bigdata@hadoop01 ~]$ echo $USER
bigdata
1
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
...
1
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
1
2
3

(2)给变量A重新赋值

[bigdata@hadoop01 ~]$ A=12
[bigdata@hadoop01 ~]$ echo $A
12
1
2
3

(3)撤销变量A

[bigdata@hadoop01 ~]$ unset A
[bigdata@hadoop01 ~]$ echo $A
 
1
2
3

(4)声明静态的变量B=2,不能unset

[bigdata@hadoop01 ~]$ readonly B=2
[bigdata@hadoop01 ~]$ unset B
-bash: unset: B: 无法反设定: 只读 variable
1
2
3

(5)在bash中,变量默认类型都是字符串类型,无法直接进行数值运算

[bigdata@hadoop01 ~]$ C=1+1
[bigdata@hadoop01 ~]$ echo $C
1+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
1
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  
1
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
1
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
1
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
1
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 #$@代表命令行中所有的参数
1
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
1
2
3
4
5
6
7
8
9
10
11
12