outlook 发表于 2018-8-20 10:18:33

shell(一)

  变量
  {}避免混淆变量,echo "this is ${name}qingdao"
  位置变量
  内建变量
  解释
  $0
  命令行中的脚本名字
  $1
  第一个命令行参数
  $2
  第二个命令行参数
  …..
  …….
  $9
  第九个命令行参数
  $#
  命令行参数的数量
  $@
  所有命令行参数
  $$
  $?
  命令执行结果
  $* 和 $@ 的区别为:
  $* 和 $@ 都表示传递给函数或脚本的所有参数,不被双引号(" ")包含时,都以"$1" "$2" … "$n" 的形式输出所有参数。
  但是当它们被双引号(" ")包含时,
  "$*" 会将所有的参数作为一个整体,以"$1 $2 … $n"的形式输出所有参数;"$@" 会将各个参数分开,以"$1" "$2" … "$n" 的形式输出所有参数。使用for语句,能看到效果
  #!/bin/bash
  echo "\$*=" $*
  echo "\"\$*\"=" "$*"
  echo "\$@=" $@
  echo "\"\$@\"=" "$@"
  echo "=========="
  echo "print each param from \$*"
  for var in $*
  do
  echo "$var"
  done
  echo "=========="
  echo "print each param from \$@"
  for var in $@
  do
  echo "$var"
  done
  echo "=========="
  echo "print each param from \"\$*\""
  for var in "$*"
  do
  echo "$var"
  done
  echo "=========="
  echo "print each param from \"\$@\""
  for var in "$@"
  do
  echo "$var"
  done
  echo "======友好提示版===="
  count=1
  for param in "$*"
  do
  echo "\$* parameter #$count=$param"
  count=$[ $count + 1 ]
  done
  count=1
  for param in "$@"
  do
  echo "\$@ parameter #$count=$param"
  count=$[ $count +1 ]
  done
  echo "=========="
  echo $?
  echo $0
  shell条件测试
  在shell中的while,if进行条件测试的时候用,=,!=这中数学符号好像行不通,
  大多数情况下,可以使用测试命令来对条件进行测试。比如可以比较字符串、判断文件是否存在及是否可读等等… 通常用” [ ] “来表示条件测试。注意这里的空格很重要。要确保方括号的空格。
  [ -f "somefile" ] :判断是否是一个文件
  [ -x "/bin/ls" ] :判断/bin/ls是否存在并有可执行权限
  [ -n "$var" ] :判断$var变量是否有值
  [ "$a" = "$b" ] :判断$a和$b是否相等 -r file     用户可读为真
  -w file     用户可写为真
  -x file     用户可执行为真
  -f file     文件为正规文件为真
  -d file     文件为目录为真
  -c file     文件为字符特殊文件为真
  -b file     文件为块特殊文件为真
  -s file     文件大小非0时为真
  -t file     当文件描述符(默认为1)指定的设备为终端时为真
  对于不含变量的任务简单shell脚本一般能胜任。但在执行一些决策任务时,就需要包含if/then的条件判断了。shell脚本编程支持此类运算,包括比较运算、判断文件是否存在等。基本的if条件命令选项有:
  - eq —比较两个参数是否相等(例如,if [ 2 –eq 5 ])
  -ne —比较两个参数是否不相等
  -lt —参数1是否小于参数2
  -le —参数1是否小于等于参数2
  -gt —参数1是否大于参数2
  -ge —参数1是否大于等于参数2
  -f — 检查某文件是否存在(例如,if [ -f "filename" ])
  -d — 检查目录是否存在
  A=1
  B=
  #判断值是否存在
  if [ $A ];then echo "is found " ; else echo "not found" ; fi
  结果is found
  if [ $B ];then echo "is found " ; else echo "not found" ; fi
  结果not found
  if [ $C ];then echo "is found " ; else echo "not found" ; fi
  结果not found
  #判断值是否空
  if [ -z $A ];then echo "is null " ; else echo "not null" ; fi
  结果not null
  if [ -z $B ];then echo "is null " ; else echo "not null" ; fi
  结果is null
  if [ -z $C ];then echo "is null " ; else echo "not null" ; fi
  结果is null
  [ -d /home/test ] && echo 'Directory found' || echo 'Directory not found'
  [ $(id -u) -gt 0 ] && echo "please use root run the script! " && exit 1
  数学计算用 $[]
  `seq 1 5`$(1 5)
  数组
  
  read
  -p 提示符-t 等待的秒数
$ read -p '>>' -t 10 arg  
>>nihao
  
$ echo $arg
  
nihao
  反引号和$()的区别:
  反引号本身就对\进行了转义,保留了本身意思,如果我们想在反引号中起到\的特殊意义,我们必须使用2个\来进行表示。
  反引号中: \\ = \
  $()中:\ = \
  注意:反引号是老的用法,()是新的用法,不管是在学习测试中,还是在实际工作中,()是新的用法,不管是在学习测试中,还是在实际工作中,()的用法都是被推荐的。
  3.单引号和双引号
  Shell脚本中的单引号和双引号一样都是字符串的界定符,单引号用于保持引号内所有字符的字面值,而双引号有些情况则特殊。如果字符串中有特殊字符需要处理时就用双引号。
  注:单引号标注的字符中不能再出现单引号。
  调试脚本
  bash脚本在开头出现了set -u 和 set -e 两行是什么作用,set -e   设置该选项后,当脚本中任何以一个命令执行返回的状态码不为0时就退出整个脚本(默认脚本运行中某行报错会继续往下执行),这样就不必设置很多的判断条件去判断每个命令是否执行成功,特别那些依赖很强的地方,脚本任何一处执行报错就不应继续执行其他语句的时候就特别有用,之前写的一些像LAMP的安装脚本就深有体会。。。
  当想根据命令执行的返回值,输出对应的log时,最好不要采用set -e选项,而是通过配合exit 命令来达到输出log并退出执行的目的。


页: [1]
查看完整版本: shell(一)