Linux Shell脚本 学习笔记

来源:互联网 发布:红鸟网络是培训机构吗 编辑:程序博客网 时间:2024/04/19 20:42

1.第一个shell脚本
打开文本编辑器(可以使用 vi/vim 命令来创建文件),新建一个文件 test.sh,扩展名为 sh(sh代表shell),扩展名并不影响脚本执行,见名知意就好
第一行一般是这样

#!/bin/bashecho "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_nameecho ${your_name}

已定义的变量,可以被重新定义

your_name="tom"echo $your_nameyour_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:binexport PATH=/opt/myapp/bin:$PATH    #给PATH重新赋值,注意引用了$PATH,即添加echo $PATH    #输出  /opt/myapp/bin:/usr/bin:bin  #在原PATH左侧加了东西export PATH=/usr/binecho $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