目录
[1.2 shell 作为一门语言](#1.2 shell 作为一门语言)
[2.shell 语法](#2.shell 语法)
[2.1 shell脚本的定义与执行](#2.1 shell脚本的定义与执行)
[(2)程序开头第一行 必须写shell的类型](#(2)程序开头第一行 必须写shell的类型)
[2.2 shell变量](#2.2 shell变量)
[2.2.2 环境变量](#2.2.2 环境变量)
[2.2.4 变量的特殊用法:" " ` ` ' ' \ () {}](#2.2.4 变量的特殊用法:" "
' ' \ () {})
1.shell概述
shell 的两层含义:
既是一种应用程序 , 又是一种程序设计语言
1.1作为应用程序:
交互式地解释、执行用户输入的命令,将用户的操作翻译成机器可以识别的语言,完成相应功能
称之为 shell 命令解析器。
shell 是用户和 Linux 内核之间的接口程序 , 用户在提示符下输入的命令都由 shell 先解释然后传给 Linux 核心,它调用了系统核心的大部分功能来执行程序、并以并行的方式协调各个程序的运行
Linux 系统中提供了好几种不同的 shell 命令解释器, 如 sh 、 ash 、 bash 等 。一般默认使用 bash 作为默认的解 释器。 编写的 shell 脚本,都是由上述 shell 命令解释器解释执行的。
shell本质是对内核起到保护作用,只有shell能够识别的命令才能够直接操作内核来控制硬件。
调用执行过程:用户输入shell命令-》shell解析命令-》内核响应-》硬件响应
shell的调用框图如下所示:
1.2 shell 作为一门语言
它定义了各种变量和参数,并提供了许多在高级语言中才具有的控制结构,包括循环和分支
完成类似于windows下批处理操作,简化我们对系统的管理与应用程序的部署 称之为shell
脚本。shell脚本是shell命令的有序集合。
shell脚本是一种脚本语言 ,我们只需使用任意文本编辑器,按照语法编写相应程序,增加
可执行权限,即可在安装shell命令解释器的环境下执行shell脚本。
2.shell 语法
2.1 shell脚本的定义与执行
(1)新建文件
指定shell脚本文件,一般以.sh作为后缀名,也可以不加,例如:test.sh
(2)程序开头第一行 必须写shell的类型
bash
#!/bin/bash
# #!用于指定当前脚本文件的shell解释器的类型 (必须放在第一行),
# 如果不写,则用默认的shell
# 这是一个注释 # 注释以 `#` 开头
#shell脚本是shell命令的有序集合,代码的构成就是命令
(3)程序编写完后,修改文件权限
chmod +x test.sh # 给test.sh加上可执行权限
chmod 777 test.sh # test.sh可读可写可执行
(4)执行脚本文件
法1:
./test.sh # 赋予执行权限后运行
法2:
bash test.sh (这种方式不需要修改文件权限)
2.2 shell变量
2.2.1自定义变量
(1)定义变量: num=1 #注意:变量等号两端不能有空格
#变量名只能包含英文字母下划线,不能以数字开头
(2)引用变量:num1=num # 新变量=旧变量名 注意:变量等号两端不能有空格
(3)输出变量:echo $num # 输出num变量的值
echo "Hello World" # 输出文本
等号两边不能直接接空格符,若变量中本身就包含了空格,则 整个字符串都要用双引号 、或单引号括起来;双 引号内的特殊字符可以保有变量特性,但是单引号内的特殊字符则仅为一般字符。
(4)清除变量:unset num #清除变量
(5)变量的其它用法:
read string
从键盘输入一个字符串付给变量 string
readonly var=100
定义一个只读变量 , 只能在定义时初始化 , 以后不能改变 , 不能被清除。
export var=300
使用 export 说明的变量,会被导出为环境变量,其它 shell 均可使用
程序:
bash
#!/bin/bash # 指定shell解释器(必须放在第一行)
#定义变量
#shell脚本中没有数据类型可言,所以定义变量时不需要加数据类型
#shell脚本中,赋值操作时不能在等号两边加空格
#NUM = 1 #错误
NUM=6
#引用变量
# $变量名 取一个变量的值
i=$NUM
#输出变量
echo "NUM:"
echo $NUM
echo "i:"
echo $i
#清除变量
unset NUM
echo "*************"
echo $NUM
echo "开始 输入 str"
#使用read从终端读取数据保存在变量中
read str
echo "str = $str"
#使用readonly创建一个只读的变量
readonly n=888
echo "n = $n"
#指定变量初始化后不能再次修改变量的值,只能使用
#n=666
#echo "n = $n"
运行结果: 注意该shell程序执行,需要有可执行权限。
程序改权限:chmod 777 xx.sh # xx.sh可读可写可执行

2.2.2 环境变量
shell在开始执行时就已经定义了一些和系统的工作环境有关的变量,我们在shell中可以直
接使用name引用。
定义:
一般在\~/.bashrc或/etc/profile文件中(系统自动调用的脚本)使用 export设置 ,允许 **用户后来更改。** 传统上,所有环境变量均为大写。
**显示环境变量**
使用 env 命令可以查看所有的环境变量。
**清除环境变量**
使用 unset 命令清除环境变量
**常见环境变量:**
HOME :用于保存注册目录的完全路径名。
PATH :用于保存用冒号分隔的目录路径名, shell 将按 PATH 变量中给出的顺序搜索这些目录,找到的第一个与命令名称一致的可执行文件将被执行。
PATH=HOME/bin:/bin:/usr/bin;export PATH
HOSTNAME :主机名
SHELL :默认的 shell 命令解析器
LOGNAME :此变量保存登录名
PWD :当前工作目录的绝对路径名
2.2.2.1临时设置环境变量
在终端执行命令
MY_SHELL_NUM=999
export MY_SHELL_NUM
运行结果:
(1) 使用 env 命令可以查看所有的环境变量
(2)使用echo输出该变量结果
2.2.2.2永久设置环境变量
需要在配置文件(~/.bashrc或/etc/profile)中进行设置即可,设置完毕后需要通过
source 命令配置文件 立即生效 或 重新打开系统。
一般环境变量类似c语言中的全局变量,可以在shell脚本文件中任意使用。
以 ~/.bashrc 为例:
(1)打开文件: vi ~/.bashrc
(2)末尾加入环境变量:
MY_SHELL_NUM1=888
export MY_SHELL_NUM1
(3)保存退出,在终端执行:source ~/.bashrc
(4)执行 env 命令,查看结果,或执行 echo $ MY_SHELL_NUM1
2.2.2.3多个常用环境变量调用
程序:
bash
#!/bin/bash
#PATH=$HOME/bin:/bin:/usr/bin;export PATH
echo "You are welcome to use bash"
echo "Current work dirctory is $PWD"
echo "the host name is $HOSTNAME"
echo "your home dir $HOME"
echo "Your shell is $SHELL"
echo "user env val is $MY_SHELL_NUM1"
echo "系统路径: $PATH"
echo "---系统路径:--- "
echo $PATH | tr ':' '\n' # 按行显示,更易读
运行结果:

2.2.3预设变量
# :传给 shell 脚本参数的数量
* :传给 shell 脚本参数的内容
1 、 2 、 3 、 ... 、 9 :运行脚本时传递给其的参数, 用空格隔开
? :命令执行后返回的状态
"?" 用于检查上一个命令执行是否正确 ( 在 Linux 中,命令退出状态为 0 表示该命令正确 执行,任何非 0 值表示命
令出错 ) 。
$0:当前执行的进程名 # xx.sh
:当前进程的进程号 "$$" 变量最常见的用途是用作临时文件的名字以保证临时文件不会重复 程序: ```bash #! /bin/bash # 其中\为转义字符,让$0输入为字符,而不作为变量 #位置变量$0 - $9 保存从终端输入的每一个参数 echo "\$0 = $0" echo "\$1 = $1" echo "\$2 = $2" echo "\$3 = $3" echo "\$4 = $4" echo "\$5 = $5" echo "\$6 = $6" echo "\$7 = $7" echo "\$8 = $8" echo "\$9 = $9" #如果超过9,需要加大括号 echo "\$10 = ${10}" echo "\$11 = ${11}" echo " 传入的参数的个数,不包括\$0" #$#:保存命令行传入的参数的个数,不包括$0 echo "\$# = $#" echo " 传入的参数的原内容,不包括\$0" #$@或者$*:保存所有的命令行传入的参数,但是不包括$0 echo "\$@ = $@" echo "\$* = $*" echo " 当前进程的进程号" #$$:获取当前进程的进程号 echo "\$$ = $$" #read NUM # 加入这个为了,再开一个终端验证进程号是否正确 echo "执行ls获取当前目录下的内容,执行成功,则\$?的值为0,执行失败,则为非0" # $? 返回上一个命令执行的结果,如果执行成功,则$?的值为0,执行失败,则为非0 ls echo "\$? = $?" ls ABC echo "\$? = $?" ``` 运行结果:  #### **2.2.4 变量的特殊用法:****" " \` \` ' ' \\ () {}** (1)""(双引号):包含的 变量输出变量值 (2)''(单引号):包含的变量会当做字符串解释,保持原样输出。 (3)\`\`(数字键1左面的反引号): 反引号中的内容作为系统命令,并执行其内容 ,可以替换输出为 一个变量。 (4)\\ 转义字符: 同c语言 \\n \\t \\r \\a等 echo命令需加 -e转义 (5)(命令序列): 由子shell来完成, 不影响当前shell中的变量 { 命令序列 }: 在当前shell中执行, 会影响当前变量 程序: ```bash #!/bin/bash name="ASD" #双引号里面的特殊字符,会使用其特殊含义 string1="good moring $name" #单引号里面的特殊字符,都会失去特殊含义,保持原样输出 string2='good moring $name' echo $string1 echo $string2 echo " pwd 引号 测试 " #反引号:获取一个shell命令的输出结果,一般对有输出结果的命令经常去使用, #也可以使用$()与反引号等价 echo "My dir is pwd" echo "My dir is `pwd`" echo 'My dir is `pwd`' echo "My dir is $(pwd)" # 与echo "My dir is `pwd`" 等价 echo " 转义字符 测试 " #转义字符:使用时,需要在echo后面加上-e选项 echo "this \n is\ta\ntest" #保持原样输出 echo -e "this \n is\ta\ntest" echo " () {} 测试 " num=333 #由 子shell 来完成,不影响当前shell中的变量 ( num=999;echo "num1 $num" ) echo num1:$num #在 当前shell 中执行,会影响当前变量 { num=666; echo "num2 $num"; } echo num2:$num ``` 运行结果: 