# -> 表示注释在脚本中没有多行注释只有单行注释
echo -> 表示输出例如 echo "Hello Word!"
例: name="HelloWord"
注意: 变量名和等号中间不能添加空格
注意: 变量名的首字符是字母或下划线
例:
name="Hello Word and me!"
readonly name
name="111"
echo $name
执行命令: ./hello.sh
报错: ./hello.sh: line 8: name: readonly variable
例:
name="Hello Word and me!"
unset name
echo $name
执行命令: ./hello.sh
打印为空
类型一: 本地变量
作用域是整个bash进程可以使用
语法: name="Mr.H"
类型二: 局部变量
作用域: 当前代码段 (修饰符: local)
语法: local name="Mr.H"
类型三: 环境变量
作用域: 当前shell进程以及子进程 (修饰符: export)
语法: export name="Mr.H"
类型三: 位置变量
语法: ${0}
例子
one=${0}
two=${1}
three=${2}
echo "文件名${one}"
echo "姓名${two} 年龄${three}"
执行命令: $ ./hello.sh Mr.H 100
输出:
文件名./hello.sh
姓名Mr.H 年龄100
${0} : 表示文件名称
${?} : 表示返回上一个命令执行的状态返回值如下
0: 表示执行成功
1: 表示执行结果
0: 表示程序状态返回码(0-255)
例:
han = ""
temp=${?}
echo "哈哈${temp}"
执行命令: ./hello.sh
./hello.sh: line 10: han: command not found
哈哈127
注意:此处所指的上一个命令其实就是上一行执行的命令
${#} : 参数个数
${*} : 参数列表
${@} : 参数列表
${$} : 获取当前shell进程ID
${!} : 执行上一个指令进程ID
声明:
name='Han'
echo ${name}
字符串拼接
name='Han'
age=100
info="${name} ${age}"
echo ${info}
获取字符串长度 #
name="Han"
echo ${#name}
截取字符串
语法: ${变量名:开始位置:截取长度}
例:
name="wangmumu"
echo ${name:0:3}
从第几个截取到最后
name="wangmumu"
lenth=${#name}-1
echo ${name:1:lenth}
同时可以写成,第三个参数不写默认截取到最后
echo ${name:1}
字符串删除
语法: ${变量名#要删除的字符串 正则表达式}
作用: 从字符串开头(左边)开始匹配要删除的字符串
例:
name="wangmumu"
echo ${name#u}
这样是删除不了的因为这个是匹配左边的第一个字符
name="wangmumu"
echo ${name#w}
这样是可以删除的
删除某个字符前面的所有字符包含自己 *
例:
name="wangmumu"
echo ${name#*u}
执行结果:
mu
指定范围删除 a*b 意思是删除a和b之间的字符(注意a必须是第一 个字符)
例:
例:
name="wangmufmu"
echo ${name#w*f}
执行结果:
mu
泛反向删除使用(从右往左删除)
name="wangmufmu"
echo ${name##*f}
执行: wangmu
%删除
语法: ${变量名%要删除的字符串 正则表达式}
从字符串的尾部开始匹配, 删除匹配的字符串
例:
name="wangmufmu"
echo ${name%u}
结果:
wangmufm
查找指定字符串第一个,并且删除前面所有字符串包括自己
name="wangmufmu"
echo ${name%f*}
结果:
wangmu
指定删除的范围
name="wangmufmu"
echo ${name%g*u}
结果:
wan
说明: 是从第一个开始删除到g这个字符
查找指定字符最后一个,并且删除前面所有字符
name="wangmufmu"
echo ${name%%u*}
结果:
wangm
总结:
从左边删除到右边
# : 表示查询方向从左到右
## : 表示查询方向从右到左
从右边删除到左边
% : 表示查询方向从右到左
%% : 表示查询方向从左到右