shell中常用的特殊符号

在shell中常用的特殊符号罗列如下:

# ; ;; . , / \ ‘string‘| ! $ ${} $? $$ $* "string"* ** ? : ^ $# [email protected] `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 $* 则是代表所有引用变量的符号 $*将所有的引用变量视为一个整体

[email protected]

[email protected]代表所有引用变量 但符号 [email protected] 则仍旧保留每个引用变量的区段观念

$? 状态值

状态值会回传给父进程,用来检查子进程的执行状态

$$ 当前进程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匹配

= 等号

变量赋值

== 等号

代表 "等于"

!= 不等于

代表 "不等于"

^

代表行的 "开头"

时间: 2024-10-15 14:39:40

shell中常用的特殊符号的相关文章

shell中常用I/O重定向命令格式说明

命令1  >    文件1 将命令1的输出结果重定向到文件1 命令1  &>  文件1 将命令1的输出结果和标准错误输出一起重定向到文件1 命令1  >>  文件1 将命令1的输出结果追加到文件1中 命令1  2>  文件1 将命令1的标准错误输出的结果重定向到文件1中 命令1  <     文件1 将文件1作为命令1的标准输入 命令1 << 字符串1   允许连续输入数据,直到接收到字符串1(常用于邮件系统) shell中常用I/O重定向命令格式说

Shell中常用的引号

Shell之引号 在Shell中经常会使用到单引号.双引号.反引号(键盘中Tab键上方的按键).反斜线(转换某些Shell元字符的含义).如我们有时希望echo命令输出的字符中就包含$符号本身,但一般情况下,Shell会将$视为取变量值,像这样的情况我们需要使用某些功能来屏蔽$符号本身的特殊含义,使其还原字面意义. 1. 反斜线 反斜线可以将紧随其后的单个字符视为字面意义上的字符,如*在Shell中代表任意字符,在查找时经常会使用*来查找多个匹配的文件,然而有可能你需要找的就是*字符本身,此时,

[Tips] Shell中常用的环境变量

常用环境变量 HOME: 使用者的目录地址 BASH: 目前使用的shell HISTSIZE: 保留历史命令的数目上限 PATH:系统默认的可执行文件搜索路径 LANG:系统使用的编码.很多程序是根据系统指定的编码去解析输入文件,如果编码不正确,很多文件就无法正确解析. RANDOM:随机产生一个0~32767之间的随机数 PS1:即命令提示符的格式,就是shell命令行前方的图标. $:表示当前shell的pid $> echo $$ ?:上一个shell命令的返回值 OSTYPE:系统类型

linux shell中的各种奇怪符号

有段时间没有写shell了,今天偶尔看到一个shell文件内容.里面有些特殊的用法,只觉得有印象但就是说不出具体的功能,就又查了一下.顺便记录下来,防备以后参考. 首先,从脚本之家的一篇文章中借鉴些东西(http://www.jb51.net/article/60326.htm),说说shell中的各种括号,可以列举的有以下几种: ${var} $(cmd) ${var:-string},${var:+string},${var:=string},${var:?string} ${var%pat

SHELL中常用特殊变量

$0 获取当前执行的SHELL脚本的文件名,包括路径. 注:basename 只要文件名,dirname 只要文件所以路径. $n 获取当前的执行的shell脚本的第n个参数值,n=1-9,当n为0时表示脚本的文件名,如果n大于9,用大括号括起${10}. $# 获取当前shell命令行终参数的总个数,命令演示如上图所示. $? 获取执行上一个指令的返回值(0为成功,非0为失败)#这个变量很常用

shell中常用的方法

<1>Linux Shell 脚本中字符串的连接方法 [[email protected] company]# var1=/etc/[[email protected] company]# var3=${var1}'yum.repos.d/'[[email protected] company]# echo $var3/etc/yum.repos.d/

shell中常用命令

shell特殊符号cut命令* *号表示统配字符? ?表示一个任意字符# #号注释字符,被注释的内容不会生效\ \符号表示脱意字符,给特殊符号脱离原有的特殊用法 cut用于分段cut -d 分割符 -f 过滤字段 /文件-d 指定分割符,使用逗号分隔可以显示多个字段,如3,6-f 指定第几列字符-c 切割区间字符,如3-6区间的字符 [[email protected] tmp]# cat passwd |head -5 |cut -d ":" -f 1 cut截取第一段内容 root

python中常用的正则表达式符号

'.' 默认匹配除\n之外的任意一个字符,若指定flag DOTALL,则匹配任意字符,包括换行 '^' 匹配字符开头,若指定flags MULTILINE,这种也可以匹配上(r"^a","\nabc\neee",flags=re.MULTILINE) '$' 匹配字符结尾,或e.search("foo$","bfoo\nsdfsf",flags=re.MULTILINE).group()也可以 '*' 匹配*号前的字符0次或

正则表达式中常用的元符号

^ 一行的开始标志如^bigeyyes匹配到所有以bigeyyes开头的行 $ 一行的结束标志如$bigeyyes 匹配到所有以bigeyyes结尾的行 ?或 . 匹配任意一个非换行字符,如big?eyes匹配到big后接一个任意字符,然后是eyyes的行 * 匹配任意0个或者多个字符 [xxx]或[x-x] 匹配字符集或者某一范围内的一个字符,如seq[01]匹配一行中所有seq0或者seq1: [xxx]可以罗列非连续的字符([afgi])[x-x]可以罗列连续字符([a-g]) [^] 匹