在
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匹配
= 等号
变量赋值
== 等号
代表
"等于"
!= 不等于
代表
"不等于"
^
代表行的
"开头"
转载于:https://blog.51cto.com/tanght/1032480