目录

引用

命令执行顺序

变量

特殊变量


引用

为防止shell解释一些东西,所以就有了引用,四种符号  " ' ` \

双引、单引和反引号

使用反斜线实现屏蔽,转义。反斜线引用单个字符时,称它为转义字符

双引号除$ ` \ 三种符号外,引用所有内容,称为弱引用

[root@localhost script]# echo "$TERM pwd "
xterm pwd

[root@localhost script]# echo "`ls` pwd "
passwd
user pwd

[root@localhost script]# echo "\`ls\` pwd "
`ls` pwd

单引号引用所有内容,没有字符拥有特殊含义,称为强引用

反引号

shell试图替代单词hello为系统命令并执行它,因为hello脚本或命令不存在,返回错误信息。

[root@localhost script]# echo `hello`
-bash: hello: command not found
[root@localhost script]# echo `date`
Mon Dec 30 18:08:21 CST 2013




如果使用引用得到的结果不理想,再试另一种,毕竟只有三种引用方式,可以充分尝
试。


反斜线\

引用单个字符时,称它为转义字符,

最强引用,可以转义单引号

引用


单引号''
引用一串字符

强引用,单引号强,只有一个


引用


双引号""

保留$ ` \ 三种符号的特殊含义

弱引用,双引号

弱,有两个

引用

当使用字符时,应总是使用双引号,无论它是单个字符串或是多个单词




反引号``
命令替换
命令替换



命令执行顺序
&&,||,(),{} 四个符号的运用
shell脚本执行命令的时候,有时候会依赖于前一个命令是否执行成功。而&&和||就是用来判断前一个命令执行效果的。

1  &&  与
  使用方法:命令1 &&  命令2
  这个方式简单明了,命令1如果返回结果为真(即执行返回为0,成功执行)后,命令2才被执行
  换句话说,如果命令1执行成功&&那么执行命令2
  这里有个命令
  [ -f /home/dellogs.sh ] && echo "清除日至脚本存在"
  总之,&&符号代表如果第一个命令执行成功才执行第二个命令。
2  ||  或
  使用方法:命令1 || 命令2
  ||命令,如果命令1没有执行成功则执行命令2
  如简单例子
  cp wopper.txt oop.txt || echo "cp命令执行没有成功"
  如果||左边的命令没有执行成功,则屏幕中除显示“cp命令执行没有成功”
  下面给出一个更为实用的例子,
  awk ‘{print$1,$5}’ acc.qrt >qtr.tmp || echo "sorry the payroll(薪水) extraction(抽取) did'not work" | mail root
3 除了使用&&和||这两方法外,还可以用(),{}这两个符号把命令连接起来
 ()和{}存在的目的只是为了,能一个shell或子shell中执行一组命令
  使用方法(命令1;命令2;命令3;...)和{命令1;命令2;命令3;...}
  这种情况比较少遇到,一般要和&&,||两个命令一起使用。
  例如
  comet monthent || (echo “Hello,quess what! comet did not work”| mail root;exit)


变量

变量的赋值有五种:使用read命令,直接赋值,使用命令行参数,使用命令行的输出结果,从文件读取。
1 先说一下从read命令吧:(主要是在需要交互时使用)
Read命令是系统内置命令,语法格式为:
read  变量1   变量2
当Shell脚本执行到read命令时,将暂停脚本的执行并等待键盘的输入,当用户输入完毕并且敲下回车之后,将完成赋值操作,脚本继续执行。
Read指令的规则:

多个数据或变量之间用空格隔开
若变量个数与数据个数相等时,对应取值
若变量个数大于数据个数时,没有输入数据的变量取空值
若变量个数小于数据个数时,将多余的数据赋给最后一个变量(也就是把空格当成字符串处理)

例子:
#!/bin/bash
echo -n “ please enter your name”  //-n 表示用户输入和提示信息在同一行
read name
echo “your name is $name”
#!/bin/bash
echo “Please  enter  your  first name  and last name :”
read first last
echo “your first name is $first”
echo “your last name is $last”

2 第二种赋值方法就是直接给变量赋值(这种赋值方法主要是在不需要交互时,并且参数不需要修改时使用)
例如:name=xiaosu
     gender=man
3 第三种赋值方法是使用命令行参数赋值。(这种赋值方法是参数需要经常变化,并且不需要交互时使用)
这种赋值方法,也就是直接在命令后面跟参数,然后系统用$1来引用第一个参数。
4 第四种方法是利用命令的输出结果赋值(这种赋值方法可以直接处理上个命令产生的数据)
在Shell程序中,可以将一个命令的输出结果来当做变量,不过需要在赋值语句中使用反引号
例如currentdir=`pwd`
    echo $currentdir
5 最后一种赋值方法是从文件中读入数据
这种方式就适合处理大批量的数据,直接把相应的数据写入文件,然后运行脚本即可。
通常是通过while循环一行行读入数据,即没循环一次,就从文件中读取一行数据,直到读取到文件的结尾。
例如:
#!/bin/bash
ls *.sh >execfile
while read LINE
do
chmod a+x $LINE
done这个脚本使用了while..do..done 结构,最后一行表示从文件execfile读取数据。while read LINE表示 每次循环读入一行数据并赋值给变量LINE。

6 变量的输出
最简单的方法就是使用echo
如果想输出格式化的字符串,就需要使用printf,用法和C语言类似
printf 命令的格式说明符
\”    输出双引号
\\    输出反斜杠
\a    响铃
\n    换行
\r    回车


特殊变量
# vi variable
#!/bin/sh
echo "number:$#"
echo "scname:$0"

echo "first:$1"
echo "second:$2"
echo "argume:$@"
echo "show parm list:$*"
echo "show process id:$$"
echo "show precomm stat:$?"
# chmod +x variable
# ./variable aa bb
number:2
scname:./variable
first:aa
second:bb
argume:aa bb
show parm list:aa bb
show process id:24544
show precomm stat:0
通过显示结果可以看到:
$# 是传给脚本的参数个数
$0 是脚本本身的名字
$1 是传递给该shell脚本的第一个参数
$2 是传递给该shell脚本的第二个参数
$@ 是传给脚本的所有参数的列表
$* 是以一个单字符串显示所有向脚本传递的参数,与位置变量不同,参数可超过9个

该变量包含了所有输入的命令行参数值。如果您运行showrpm openssh.rpm w3m.rpm webgrep.rpm
此时 $* 包含了 3 个字符串,即openssh.rpm, w3m.rpm and webgrep.rpm.

$$ 是脚本运行的当前进程ID号
$? 是显示最后命令的退出状态,0表示没有错误,其他表示有错误