在 shell中常用的特殊符号罗列如下:
# ; ;; . , / \ 'string'| ! $ ${} $? $$ $* "string"* ** ? : ^ $# $@ `command`{} [] [[]]
() (()) || && {xx,yy,zz,...}~ ~+ ~- & \<...\> + - %= == !=
# 井号 (comments)
注释字符 该句不会被执行
~ 帐户的 home 目录
用户的 home目录如:cd ~
; 分号
连续指令符号 如 :cd ~/backup ; mkdir startup ; cp ~/.* startup/.
;; 连续分号 (Terminator)
case语句中担任终结符
如 :
case "$fop" in
help) echo "Usage: Command -help -version filename" ;;
version) echo "version 0.1" ;;
esac
. 逗号
1 .代表当前目录 ..代表上层目录
2 正则表达式中 .代表匹配一个字元
'string' 单引号
括住部分将被视为单一字串 特殊字符失效
"string" 双引号
括住部分将被视为单一字串 它防止通配符扩展但允许变量扩展
如 heyyou=homeecho "$heyyou"
`command` 倒引号
括住部分为命令 命令执行
, 逗点
分割功能 如 t=$((a=5+3,b=7-1,c=15/3))或者echo "a=$a,b=$b,c=$c"
/ 斜线
1 根目录或目录分隔号
2 除号
\ 倒斜线
1 特殊符号的作用消失
2 放在指令的最末端 表示指令连接下一行
| 管道
连结上个指令的标准输出,做为下个指令的标准输入。
! 惊叹号
1 条件判断 逻辑否 如: !=
2 规则表达式 逻辑否 如: ls a[!0-9]
: 冒号
1 内建指令: "什么事都不干",但返回状态值 0
: 返回状态码 0
: > f.$$等同于 cat /dev/null > f.$$
: ${HOSTNAME?} ${USER?} ${MAIL?} 检查这些环境变数是否已设置,没有设置的将会以标准错
误显示错误讯息
2 环境变量分割符
PATH=$PATH:$HOME/fbin:$HOME/fperl:/usr/local/mozilla
? 问号
匹配一个任意的字元 如: # ls a?a1
* 星号
1 在文件名扩展上用来代表任何字元
2 在运算时代表 "乘法" 如 expr 3 \* 4
3 ** 次方运算 如 let "sus=2**3"echo "
$ 钱号
1 变量代表符号
2 正则中表示行末另外 如 grep -E ".$" 或sed 's/\.$//g' 或awk '/\.$/'
${} 变量的正规表达式
bash中 ${}用法:
${parameter:-word} parameter定义非空时 ,才不替换为word不赋值,否则替换但不赋值
${parameter:=word} parameter定义非空时 ,才不替换不赋值;否则替换并赋值
${parameter:?word} parameter若非真正的值 ,脚本退出
${parameter:+word} parameter若非真正的值 ,不替换不赋值;否则替换不赋值
${parameter:offset} parameter从第 offset位向右子串
${parameter:offset:length} parameter从第 offset位向右length长度的子串
${#parameter} parameter变量长度
${parameter#word} 删除 parameter最左端匹配第一个word
${parameter##word} 删除 parameter中从左向右能匹配的最长word
${parameter%word} 删除 parameter最右端匹配第一个word
${parameter%%word} 删除 parameter中从右向左能匹配的最长word
${parameter/pattern/string} 以 string替换parameter中最左端的pattern
${parmeter//pattern/string} 以 string替换所有parameter中的pattern
$[digit]
1 $0指令本身为 0,
2 $1其后依此类推 引用第几位变量但两位数以上,则必须使用 {}括住 如${12}
3 $* 则是代表所有引用变量的符号 $*将所有的引用变量视为一个整体
$@
$@代表所有引用变量 但符号 $@ 则仍旧保留每个引用变量的区段观念
$? 状态值
状态值会回传给父进程,用来检查子进程的执行状态
$$ 当前进程 ID
() 指令群组
用括号将一串连续指令括起来称为指令群组 如: (cd ~ ; vcgh=`pwd` ; echo $vcgh),指令群组
有一个特性 会以产生 subshell来执行这组指令
(())
算数运算 c=$((a+b))等同于let c=a+b等同于c=`expr $a + $b`等同于c=`echo $a + $b|bc`
{} 大括号
1 定义函数
2 字串的组合 如 {userA,userB}-{home,bin}结果为userA-home, userA-bin, userB-home, userB
-bin
[] 中括号
1 在流程控制中表示判断式 如: if [ "$?" != 0 ]
2 在正则表达式中表示 "范围"或"集合" rm -r 200[1234]
[[]]
与 []符号,基本上作用相同但允许在其中直接使用 || 与 && 逻辑等符号 如:[[ $ak > 5 && $ak
< 9 ]] && echo "ok"
|| 逻辑符号
代表 or 逻辑的符号。
&& 逻辑符号
代表 and 逻辑的符号。
& 后台工作
表示将该指令列放入后台中工作 如: tar cvfz data.tar.gz data > /dev/null &
\<...\> 单字边界
规则表达式 如: grep -E '\<man\>' file
+ 加号 (plus)
1 表示 "加法" 如:expr 1 + 2 + 3
2 规则表达式中用来表示 "很多个"的前面字元 如: grep '10\+9' fileB109109 前面必须加上
escape 字元。
- 减号 (dash)
1 表示 "减法" 如:expr 10 - 2
2 系统指令 tar xpvf - -符号从标准输入读取资料。
3 cd - 回到 "上一次"工作目录。
% 除法 (Modulo)
1 表示 "除法" 如:expr 10 % 2
2 规则表达式中 ${parameter%word} %表示最短的 word 匹配 ${parameter%%word} %%表示最长的
word匹配
= 等号
变量赋值
== 等号
代表 "等于"
!= 不等于
代表 "不等于"
^
代表行的 "开头"