您的位置:首页 > 运维架构 > Shell

shell中常用特殊符号

2015-08-11 19:11 351 查看
http://blog.chinaunix.net/uid-25063573-id-3376648.html

在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 '\' 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匹配

= 等号

变量赋值

== 等号

代表 "等于"

!= 不等于

代表 "不等于"

^

代表行的 "开头"
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: