加入收藏 | 设为首页 | 会员中心 | 我要投稿 南通站长网 (https://www.0513zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 教程 > 正文

shell编写概括

发布时间:2021-11-12 14:53:03 所属栏目:教程 来源:互联网
导读:变量引用 $(VAR): 会将VAR当做一条命令来执行 $VAR: 单引号中包含的变量, 不会被引用, 仍然输出$VAR $VAR: 双引号中包含的变量, 会被引用成$VAR的值输出 ``: 优先执行其中的命令, 用在字符串中时, 仅在当中有效 有时需要在一个字符串变量中定义一个命令并预先
变量引用
$(VAR): 会将VAR当做一条命令来执行
'$VAR': 单引号中包含的变量, 不会被引用, 仍然输出$VAR
"$VAR": 双引号中包含的变量, 会被引用成$VAR的值输出
``: 优先执行其中的命令, 用在字符串中时, 仅在""当中有效
有时需要在一个字符串变量中定义一个命令并预先包含一个变量名, 在使用时再转换成变量名, 此时可通过eval命令来达到目的.
 
CMD='eval echo $VALUE'
VALUE="Hello"
 
$CMD
# 执行echo "Hello", 输出"Hello"
 
特殊变量
$0: 获取当前执行脚本的文件名,包括路径
$n: 获取当前执行的shell脚本的第N个参数, n=1..9, 当n为0时表示脚本的文件名, 如果n大于9, 可用大括号括起来如${10}
$@: 这个程序的所有参数"$1" "$2" "$3"..., 这是将参数传递给其他程序的最佳方式, 因为会保留所有内嵌在每个参数里的空白
$*: 获取当前shell的所有参数,会将所有的命令行参数视为单个字符串
$?: 代表上一个命令执行是否成功的标志,如果执行成功则$? 为0, 否则不为0
$#: 获取当前shell命令行中参数的总个数
$_: 代表上一个命令的最后一个参数
$$: 代表所在命令的PID
$!: 代表最后执行的后台命令的PID
日志输出
shell脚本开发中, 输出的语句尽量不出现在标准输出, 除非是少数的步骤提示性语句, 如果是出错信息, 应存入到自己定义的出错日志中, 以便后期维护和调试, 其它不关心的信息直接输出到/dev/null中. 否则输出信息过多, 容易耗尽缓存, 造成脚本运行卡死, 难以调试定位.
 
date: 显示日期时间的命令, 可通过此命令来作为日志的前缀, 方便定位. 一般形式为 "[ date +%Y%m%d-%H%M%S` ]"
&[n]: 代表已经存在的文件描述符, &1代表输出, &2代表错误输出, &-代表关闭与它绑定的描述符, 如2>&1 错误输出绑定到标准输出, 2>&- 等价于2>/dev/null
条件判断
使用[ ]判断
注意事项
[ $HOME == $MALL ]
 
[ ]中每个组件都需要空格键来分格, 其中的变量最好都以双引号括起来, 常量最好都以单或双括起来
[ ]中==和'='结果都完全一样, 习惯上可尽量使用==
常用参数
数值比较
 
-ne: 比较两个参数是否不相等
-lt 参数1是否小于参数2
-le 参数1是否小于等于参数2
-gt 参数1是否大于参数2
-ge 参数1是否大于等于参数2
-n:判断变量是否有值
文件比较
 
-f 检查某文件是否存在
-d 检查目录是否存在
-x:判断是否存在并有可执行权限
-d: 文件为目录为真
-c: 文件为字符特殊文件为真
-b: 文件为块特殊文件为真
-s: 文件大小非0时为真
-t: 当文件描述符(默认为1)指定的设备为终端时为真
权限比较
 
-r: 用户可读为真
-w: 用户可写为真
-x: 用户可执行为真

(编辑:南通站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读