linux指令(1)

1.Linux输出重定向

  1. >: 会重写文件,如果文件里面有内容会覆盖。
  2. >>这个是将输出内容追加到目标文件中。如果文件不存在,就创建文件。
  3. >>:追加文件,也就是如果文件里面有内容会把新内容追加到文件
  4. 是定向输出到文件,如果文件不存在,就创建文件;如果文件存在,就将其清空。

    2.exec命令
    用于调用并行执行指令

3.tee命令
tee命令用于将数据重定向到文件,另一方面还可以提供一份重定向数据的副本作为后续命令的stdin。简单的说就是把数据重定向到给定文件和屏幕上。

-a:向文件中重定向时使用追加模式;
-i:忽略中断(interrupt)信号。

4.set指令
set指令能设置所使用shell的执行方式,可依照不同的需求来做设置。

参数说明:

-a  标示已修改的变量,以供输出至环境变量。
-b  使被中止的后台程序立刻回报执行状态。
-C  转向所产生的文件无法覆盖已存在的文件。
-d  Shell预设会用杂凑表记忆使用过的指令,以加速指令的执行。使用-d参数可取消。
-e  若指令传回值不等于0,则立即退出shell。
-f   取消使用通配符。
-h  自动记录函数的所在位置。
-H Shell  可利用"!"加<指令编号>的方式来执行history中记录的指令。
-k  指令所给的参数都会被视为此指令的环境变量。
-l  记录for循环的变量名称。
-m  使用监视模式。
-n  只读取指令,而不实际执行。
-p  启动优先顺序模式。
-P  启动-P参数后,执行指令时,会以实际的文件或目录来取代符号连接。
-t  执行完随后的指令,即退出shell。
-u  当执行时使用到未定义过的变量,则显示错误信息。
-v  显示shell所读取的输入值。
-x  执行指令后,会先显示该指令及所下的参数。
+<参数>  取消某个set曾启动的参数。

5.Linux指令中if条件语句
每个if语句都要用fi结束,其应用格式如下:

if  条件
then
   Command1
[else
   Command2]  #中括号表示else语句可以没有
fi            #别忘了这个结尾

if语句忘了结尾fi,在运行时报错如下:
test.sh: line xx: syntax error: unexpected end of fi

Linux shell if 语法
基本语法:
if [ command ]; then
符合该条件执行的语句
fi
2、扩展语法:
if [ command ];then
符合该条件执行的语句
elif [ command ];then
符合该条件执行的语句
else
符合该条件执行的语句
fi

注意:
1、[ ]表示条件测试。注意这里的空格很重要。要注意在’[‘后面和’]’前面都必须要有空格
2、在shell中,then和fi是分开的语句。如果要在同一行里面输入,则需要用分号将他们隔开。
3、注意if判断中对于变量的处理,需要加引号,以免一些不必要的错误。没有加双引号会在一些含空格等的字符串变量判断的时候产生错误。比如[ -n “$var” ]如果var为空会出错
4、判断是不支持浮点值的
5、如果只单独使用>或者<号,系统会认为是输出或者输入重定向,虽然结果显示正确,但是其实是错误的,因此要对这些符号进行转意
6、在默认中,运行if语句中的命令所产生的错误信息仍然出现在脚本的输出结果中
7、使用-z或者-n来检查长度的时候,没有定义的变量也为0
8、空变量和没有初始化的变量可能会对shell脚本测试产生灾难性的影响,因此在不确定变量的内容的时候,在测试号前使用-n或者-z测试一下
9、? 变量包含了之前执行命令的退出状态(最近完成的前台进程)(可以用于检测退出状态)

常用参数:
文件/目录判断:
[ -a FILE ] 如果 FILE 存在则为真。
[ -b FILE ] 如果 FILE 存在且是一个块文件则返回为真。
[ -c FILE ] 如果 FILE 存在且是一个字符文件则返回为真。
[ -d FILE ] 如果 FILE 存在且是一个目录则返回为真。
[ -e FILE ] 如果 指定的文件或目录存在时返回为真。
[ -f FILE ] 如果 FILE 存在且是一个普通文件则返回为真。
[ -g FILE ] 如果 FILE 存在且设置了SGID则返回为真。
[ -h FILE ] 如果 FILE 存在且是一个符号符号链接文件则返回为真。(该选项在一些老系统上无效)
[ -k FILE ] 如果 FILE 存在且已经设置了冒险位则返回为真。
[ -p FILE ] 如果 FILE 存并且是命令管道时返回为真。
[ -r FILE ] 如果 FILE 存在且是可读的则返回为真。
[ -s FILE ] 如果 FILE 存在且大小非0时为真则返回为真。
[ -u FILE ] 如果 FILE 存在且设置了SUID位时返回为真。
[ -w FILE ] 如果 FILE 存在且是可写的则返回为真。(一个目录为了它的内容被访问必然是可执行的)
[ -x FILE ] 如果 FILE 存在且是可执行的则返回为真。
[ -O FILE ] 如果 FILE 存在且属有效用户ID则返回为真。
[ -G FILE ] 如果 FILE 存在且默认组为当前组则返回为真。(只检查系统默认组)
[ -L FILE ] 如果 FILE 存在且是一个符号连接则返回为真。
[ -N FILE ] 如果 FILE 存在 and has been mod如果ied since it was last read则返回为真。
[ -S FILE ] 如果 FILE 存在且是一个套接字则返回为真。
[ FILE1 -nt FILE2 ] 如果 FILE1 比 FILE2 新, 或者 FILE1 存在但是 FILE2 不存在则返回为真。
[ FILE1 -ot FILE2 ] 如果 FILE1 比 FILE2 老, 或者 FILE2 存在但是 FILE1 不存在则返回为真。
[ FILE1 -ef FILE2 ] 如果 FILE1 和 FILE2 指向相同的设备和节点号则返回为真。

字符串判断
[ -z STRING ] 如果STRING的长度为零则返回为真,即空是真
[ -n STRING ] 如果STRING的长度非零则返回为真,即非空是真
[ STRING1 ]  如果字符串不为空则返回为真,与-n类似
[ STRING1 == STRING2 ] 如果两个字符串相同则返回为真
[ STRING1 != STRING2 ] 如果字符串不相同则返回为真
[ STRING1 < STRING2 ] 如果 “STRING1”字典排序在“STRING2”前面则返回为真。
[ STRING1 > STRING2 ] 如果 “STRING1”字典排序在“STRING2”后面则返回为真。

数值判断
[ INT1 -eq INT2 ] INT1和INT2两数相等返回为真 ,=
[ INT1 -ne INT2 ] INT1和INT2两数不等返回为真 ,<>
[ INT1 -gt INT2 ] INT1大于INT2返回为真 ,>
[ INT1 -ge INT2 ] INT1大于等于INT2返回为真,>=
[ INT1 -lt INT2 ] INT1小于INT2返回为真 ,<
[ INT1 -le INT2 ] INT1小于等于INT2返回为真,<=

逻辑判断
[ ! EXPR ] 逻辑非,如果 EXPR 是false则返回为真。
[ EXPR1 -a EXPR2 ] 逻辑与,如果 EXPR1 and EXPR2 全真则返回为真。
[ EXPR1 -o EXPR2 ] 逻辑或,如果 EXPR1 或者 EXPR2 为真则返回为真。
[ ] || [ ] 用OR来合并两个条件
[ ] && [ ] 用AND来合并两个条件

其他判断
[ -t FD ] 如果文件描述符 FD (默认值为1)打开且指向一个终端则返回为真
[ -o optionname ] 如果shell选项optionname开启则返回为真

IF高级特性:
双圆括号(( )):表示数学表达式
在判断命令中只允许在比较中进行简单的算术操作,而双圆括号提供更多的数学符号,而且在双圆括号里面的’>’,’<’号不需要转意。

双方括号[[ ]]:表示高级字符串处理函数
双方括号中判断命令使用标准的字符串比较,还可以使用匹配模式,从而定义与字符串相匹配的正则表达式。

双括号的作用:
在shell中,[ a ! = 1 | | b = 2 ]是不允许出,要用[ a ! = 1 ] | | [ b = 2 ],而双括号就可以解决这个问题的,[[ a ! = 1 | | b = 2 ]]。又比如这个[ “ a " l t " b” ],也可以改成双括号的形式((“ a "<" b”))

常用例子:
判断目录 t m p D i r i f [ ! d tmpDir”]; then
  mkdir “$tmpDir”
fi

判断普通文件 t m p D i r i f [ ! f tmpDir” ]; then
  touch “$tmpDir”
fi

判断 t m p D i r i f [ ! x tmpDir”]; then
  mkdir “ t m p D i r c h m o d + x tmpDir”
fi

是判断变量 t m p D i r i f [ ! n tmpDir” ]; then
  echo “$tmpDir is empty”
  exit 1
fi

判断两个变量是否相等
if [ “ v a r 1 "=" var2” ]; then
  echo ‘ v a r 1 e q var2’
else
  echo ‘ v a r 1 n o t e q var2’
fi

测试退出状态:
if [ $? -eq 0 ];then
echo ‘ok’
fi

number的比较:
if [ “ n u m g t 150 ] e c h o num > 150”
fi

组合判断:a>b 且 a

!/bin/sh

SYSTEM=uname -s
if [ S Y S T E M = L i n u x ] ; t h e n e c h o L i n u x e l i f [ SYSTEM = “FreeBSD” ] ; then
echo “FreeBSD”
elif [ $SYSTEM = “Solaris” ] ; then
echo “Solaris”
else
echo “What?”
fi

if利用read传参判断

!/bin/bash

read -p “please input a score:” score
echo -e “your score [$score] is judging by sys now”

if [ “ score" -ge "0" ]&&[ " score” -lt “60” ];then
echo “sorry,you are lost!”
elif [ “ score" -ge "60" ]&&[ " score” -lt “85” ];then
echo “just soso!”
elif [ “ score" -le "100" ]&&[ " score” -ge “85” ];then
echo “good job!”
else
echo “input score is wrong , the range is [0-100]!”
fi

判断文件是否存在

!/bin/sh

today=date -d yesterday +%y%m%d
file=”apache_ t o d a y . t a r . g z c d / h o m e / c h e n s h u o / s h e l l i f [ f file” ];then
echo “OK”
else
echo “error $file” >error.log
mail -s “fail backup from test” [email protected]

!/bin/bash

WEEKOFFSET= [ (date +”%V”) % 2 ]

if [ $WEEKOFFSET -eq “0” ]; then
echo “Sunday evening, put out the garbage cans.” | mail -s “Garbage cans out” your@your_domain.org
fi

挂载硬盘脚本(windows下的ntfs格式硬盘)

! /bin/sh

dir_d=/media/disk_d
dir_e=/media/disk_e
dir_f=/media/disk_f

a=ls $dir_d | wc -l
b=ls $dir_e | wc -l
c=ls $dir_f | wc -l

echo “checking disk_d…”
if [ $a -eq 0 ]; then
echo “disk_d is not exsit,now creating…”
sudo mount -t ntfs /dev/disk/by-label/software /media/disk_d
else
echo “disk_d exits”
fi

echo “checking disk_e…”
if [ $b -eq 0 ]; then
echo “disk_e is not exsit,now creating…”
sudo mount -t ntfs /dev/disk/by-label/elitor /media/disk_e
else
echo “disk_e exits”
fi

echo “checking disk_f…”
if [ $c -eq 0 ]; then
echo “disk_f is not exsit,now creating…”
sudo mount -t ntfs /dev/disk/by-label/work /media/disk_f
else
echo “disk_f exits”
fi

猜你喜欢

转载自blog.csdn.net/l_ml_m_lm_m/article/details/81567322