1.第一个shell脚本
打开文本编辑器(可以使用 vi/vim 命令来创建文件),新建一个文件 test.sh,扩展名为 sh(sh代表shell),扩展名并不影响脚本执行,见名知意就好
第一行一般是这样
#!/bin/bash
echo "Hello World !"
#!是一个约定的标记,它告诉系统这个脚本需要什么解释器来执行,即使用哪一种 Shell。
echo 命令用于向窗口输出文本。(另一个可用于终端打印的命令是printf,参数用法和c语言中相似)
运行 Shell 脚本有两种方法:
1、作为可执行程序
将上面的代码保存为 test.sh,并 cd 到相应目录:
chmod +x ./test.sh #使脚本具有执行权限
./test.sh #执行脚本
2、作为解释器参数
这种运行方式是,直接运行解释器,其参数就是 shell 脚本的文件名,如:
bash test.sh
/bin/sh test.sh
/bin/php test.php
这种方式运行的脚本,不需要在第一行指定解释器信息,写了也没用。
2.shell变量
运行shell时,会同时存在三种变量:
1) 局部变量 局部变量在脚本或命令中定义,仅在当前shell实例中有效,其他shell启动的程序不能访问局部变量。
2) 环境变量 所有的程序,包括shell启动的程序,都能访问环境变量,有些程序需要环境变量来保证其正常运行。必要的时候shell脚本也可以定义环境变量。
3) shell变量 shell变量是由shell程序设置的特殊变量。shell变量中有一部分是环境变量,有一部分是局部变量,这些变量保证了shell的正常运行
定义变量时,变量名不加美元符号
使用一个定义过的变量,只要在变量名前面加美元符号即可
变量名外面的花括号是可选的,加不加都行,加花括号是为了帮助解释器识别变量的边界
推荐给所有变量加上花括号,这是个好的编程习惯。
your_name="qinjx"
echo $your_name
echo ${your_name}
已定义的变量,可以被重新定义
your_name="tom"
echo $your_name
your_name="alibaba"
echo $your_name
使用 unset 命令可以删除变量
unset variable_name
变量被删除后不能再次使用。unset 命令不能删除只读变量
3.Shell 字符串
字符串是shell编程中最常用最有用的数据类型(除了数字和字符串,也没啥其它类型好用了),字符串可以用单引号,也可以用双引号,也可以不用引号
(1)单引号
str='this is a string'
单引号字符串的限制:
单引号里的任何字符都会原样输出,单引号字符串中的变量是无效的;
单引号字串中不能出现单引号(对单引号使用转义符后也不行)。
(2)双引号
your_name='qinjx'
str="Hello, I know your are \"$your_name\"! \n"
双引号的优点:
双引号里可以有变量
双引号里可以出现转义字符“\”: $ ,#, ! 等特殊字符有其他作用,出现在字符串中需要转义
(3)获取字符串长度
string="abcd"
echo ${#string} #输出 4
3.export命令
用来设置环境变量(上一节变量中提过)
常用环境变量有:PATH(决定了shell将到哪些目录中寻找命令或程序)
LD_LIBRARY_PATH(用于指定查找共享库(动态链接库)时除了默认路径之外的其他路径)
HOME(主目录路径)
PWD(记录当前路径)
USER(显示当前用户名字)
UID(已登用户的ID,root为0)
SHELL(显示当前所用的shell)等
PATH=/usr/bin:bin #注意":"为分隔符,而windows中是用";"
echo $PATH #输出 /usr/bin:bin
export PATH=/opt/myapp/bin:$PATH #给PATH重新赋值,注意引用了$PATH,即添加
echo $PATH #输出 /opt/myapp/bin:/usr/bin:bin #在原PATH左侧加了东西
export PATH=/usr/bin
echo $PATH #输出 /usr/bin #export功能就是直接赋值,注意与上面的区别
4.Shell 传递参数
我们可以在执行 Shell 脚本时,向脚本传递参数,脚本内获取参数的格式为:$n。n 代表一个数字,0为当前执行的脚本文件名,1 为执行脚本的第一个参数,2 为执行脚本的第二个参数,以此类推…… $# 表示传递到脚本的参数个数
./test.sh a bc def
执行脚本时,$0=./test.sh, $1=a, $2=bc, $3=def. $#=3
5.输入/输出重定向
重定向深入讲解
一般情况下,每个 Unix/Linux 命令运行时都会打开三个文件:
- 标准输入文件(stdin):stdin的文件描述符为0,Unix程序默认从stdin读取数据。
- 标准输出文件(stdout):stdout的文件描述符为1,Unix程序默认向stdout输出数据。
- 标准错误文件(stderr):stderr的文件描述符为2,Unix程序会向stderr流中写入错误信息。
默认情况下,command > file 将 stdout 重定向到 file,command < file 将stdin 重定向到 file。
如果希望 stderr 重定向到 file,可以这样写:
$ command 2 > file
如果希望 stderr 追加到 file 文件末尾,可以这样写:
$ command 2 >> file
2 表示标准错误文件(stderr)。
如果希望将 stdout 和 stderr 合并后重定向到 file,可以这样写:
(覆盖):
$ command > file 2>&1 #内容覆盖file
或
$ command 2 &> file
(追加):
$ command >> file 2>&1 #内容追加到file
举例:
保存编译信息的行命令,它把make过程打印的所有信息都保存在xxx.log中:
$make 2>&1|tee xxx.log
或:
$make 2 &> xxx.log
第一条命令是编译并保存打印信息。在Linux Shell的设备定义中,“0”表示标准输入,“1”表示标准输出,“2”表示标准出错信息输出。2>&1表示把2设备的信息重定向到1设 备;“|”是管道符号,把标准输出的信息直接传递给后面的命令;tee是创建文件并保存信息的工具;xxx.log是文件名。
这种管道的用法在Linux Shell命令中使用非常普遍。编译过程中都可以使用这个方法,生成日志文件。
第二条命令与第一条功能相同,但是写法较为简洁,就是将stderr重定向到xxx.log,并不会在屏幕上(stdout)显示出来
部分摘自:
http://www.runoob.com/linux/linux-shell-io-redirections.html