echo:打印输出,例如:echo “Hello world”;
read: 读取键盘出入,例如:read WORLD,WORLD是个变量,使用时前面加$,结合echo,echo “Hello, $WORLD”;
$ $:特殊变量,当前进程号,例如:输出当前进程:echo $$;
source:强制执行脚本文件中的全部命令,例如:source filename
date: 用来获得当前的系统时间;
使用 data 命令的%s格式控制符可以得到当前的 UNIX 时间戳,UNIX 时间戳是指从 1970 年 1 月 1 日 00:00:00 到目前为止的秒数;
$?:获取上一个命令的退出状态;
$@:表示函数的所有参数;
$#:获取传递的参数个数;
exit:退出当前shell进程
2.1 变量赋值:
注意,赋值号=的周围不能有空格,这可能和你熟悉的大部分编程语言都不一样。
2.2变量使用:
使用一个定义过的变量,只要在变量名前面加美元符号**$**即可。
推荐给所有变量加上花括号{ },这是个良好的编程习惯。
2.3变量单引号和双引号的区别:
1)如果变量的内容是数字,那么可以不加引号;
2)如果真的需要原样输出就加单引号;
3)其他没有特别要求的字符串最好都加上双引号,定义变量时加双引号是最常见的使用场景。
2.4 将命令赋值给变量:
把命令用** ( ) ∗ ∗ 包围起来 v a r i a b l e = ()**包围起来 variable= ()∗∗包围起来variable=(command),例如,log=$(cat log.txt)
2.5 只读变量:
使用 readonly 命令可以将变量定义为只读变量,只读变量的值不能被改变。
2.6 删除变量:
使用 unset 命令可以删除变量
为了防止出现格式混乱的情况,我建议在输出变量时加上双引号
运行 Shell 脚本文件时我们可以给它传递一些参数,这些参数在脚本文件内部可以使用**$n**的形式来接收,例如,$1 表示第一个参数, 2 表示第二个参数,依次类推。如果参数个数太多,达到或者超过了 10 个,那么就得用 2 表示第二个参数,依次类推。 如果参数个数太多,达到或者超过了 10 个,那么就得用 2表示第二个参数,依次类推。如果参数个数太多,达到或者超过了10个,那么就得用{n}的形式来接收了,例如 10 、 {10}、 10、{23}。{ }的作用是为了帮助解释器识别参数的边界,这跟使用变量时加{ }是一样的效果。
3.字符串:
3.1获取字符串长度:
${#string_name},string_name 表示字符串名字。
3.2字符串拼接:
在 Shell 中你不需要使用任何运算符,将两个字符串并排放在一起就能实现拼接,非常简单粗暴
1. #!/bin/bash
2. name="Shell"
3. url="http://c.biancheng.net/shell/"
4. str1=$name$url#中间不能有空格
5. str2="$name $url"#如果被双引号包围,那么中间可以有空格
6. str3=$name": "$url#中间可以出现别的字符串
7. str4="$name: $url"#这样写也可以
8. str5="${name}Script: ${url}index.html"#这个时候需要给变量名加上大括号
9. echo $str1
10. echo $str2
11. echo $str3
12. echo $str4
13. echo $str5
运行结果:
Shellhttp://c.biancheng.net/shell/
Shell http://c.biancheng.net/shell/
Shell: http://c.biancheng.net/shell/
Shell: http://c.biancheng.net/shell/
ShellScript: http://c.biancheng.net/shell/index.html
3.3 字符串截取
1) 使用 # 号截取右边字符
使用#号可以截取指定字符(或者子字符串)右边的所有字符,具体格式如下:
${string#*chars}
其中,string 表示要截取的字符,chars 是指定的字符(或者子字符串),*是通配符的一种,表示任意长度的字符串。*chars连起来使用的意思是:忽略左边的所有字符,直到遇见 chars(chars 不会被截取)。
请看下面的例子:
url="http://c.biancheng.net/index.html"
echo ${url#*:}
结果为//c.biancheng.net/index.html。
以下写法也可以得到同样的结果:
echo ${url#*p:}
echo ${url#*ttp:}
如果不需要忽略 chars 左边的字符,那么也可以不写*,例如:
url="http://c.biancheng.net/index.html"
echo ${url#http://}
结果为c.biancheng.net/index.html。
注意,以上写法遇到第一个匹配的字符(子字符串)就结束了。例如:
url="http://c.biancheng.net/index.html"
echo ${url#*/}
结果为/c.biancheng.net/index.html。url 字符串中有三个/,输出结果表明,Shell 遇到第一个/就匹配结束了。
如果希望直到最后一个指定字符(子字符串)再匹配结束,那么可以使用##,具体格式为:
${string##*chars}
请看下面的例子:
#!/bin/bash
url="http://c.biancheng.net/index.html"
echo ${url#*/} #结果为 /c.biancheng.net/index.html
echo ${url##*/} #结果为 index.html
str="---aa+++aa@@@"
echo ${str#*aa} #结果为 +++aa@@@
echo ${str##*aa} #结果为 @@@
2) 使用 % 截取左边字符
使用%号可以截取指定字符(或者子字符串)左边的所有字符,具体格式如下:
${string%chars*}
请注意的位置,因为要截取 chars 左边的字符,而忽略 chars 右边的字符,所以应该位于 chars 的右侧。其他方面%和#的用法相同,这里不再赘述,仅举例说明:
纯文本复制
#!/bin/bash
url="http://c.biancheng.net/index.html"
echo ${url%/*} #结果为 http://c.biancheng.net
echo ${url%%/*} #结果为 http:
str="---aa+++aa@@@"
echo ${str%aa*} #结果为 ---aa+++
echo ${str%%aa*} #结果为 ---