shell中的特殊字符【3】

本文介绍了Shell脚本中各种重定向方式及其特殊字符的作用,包括标准输入输出的重定向、逻辑操作、数学运算等内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

shell中的特殊字符

> &> >& >> < <>

默认情况下,总是有三个文件处于打开状态,标准输入(键盘输入)、标准输出(输出到屏幕)、标准错误(也是输出到屏幕),它们分别对应的文件描述符是0,1,2

> 重定向

scriptname >filename

重定向scriptname的输出到文件filename中去,如果文件存在则覆盖;

&>

command &>filename

command_test () { type "$1" &>/dev/null; }
#                                      ^

cmd=rmdir            # Legitimate command.
command_test $cmd; echo $?   # 0


cmd=bogus_command    # Illegitimate command
command_test $cmd; echo $?   # 1

会重定向command的标准输出(stdout)和标准错误(stderr)到文件filename中

>&

command >&2

把command的标准输出(stdout)重定向到标准错误(stderr)中;而&符号,后面接的是必须的文件描述符。不能写成,command>2,这样就成了标准输出重定向到文件名为2的文件中了,而不是重定向标准输出到标准错误中。

>>

scriptname >>filename

scriptname的输出(同>)追加到文件filenmae中,如果文件不存在则创建。

<>

[i]<>filename

打开filename这个文件用来读或者写,并且给文件指定i为它的文件描述符(file descriptor),文件不存在就会创建。

<<

这个也被称为Here-document,用来将后继的内容重定向到左侧命令的stdin中。

参见 http://blog.youkuaiyun.com/ysdaniel/article/details/6899861

<<<

这个也被称为Here-string,它的语法为:COMMAND <<< $WORD,

String="This is a string of words."

read -r -a Words <<< "$String"
#  The -a option to "read"
#+ assigns the resulting values to successive members of an array.

echo "First word in String is:    ${Words[0]}"   # This
echo "Second word in String is:   ${Words[1]}"   # is
echo "Third word in String is:    ${Words[2]}"   # a
echo "Fourth word in String is:   ${Words[3]}"   # string
echo "Fifth word in String is:    ${Words[4]}"   # of
echo "Sixth word in String is:    ${Words[5]}"   # words.
echo "Seventh word in String is:  ${Words[6]}"   # (null)
                                                 # Past end of $String.

# Thank you, Francisco Lobo, for the suggestion.

<, >

ASCII 比较

\<, >

词界符(word boundary)。这个是用在正则表达式中的一个特殊分隔符,用来标记单词的分界。

bash$ grep '\<the\>' textfile

|

管道
管道是每一个进程的标准输出都会作为下一个命令的标准输入,期间的标准输出不能跨越管道作为后继命令的标准输入

>|

强制重定向

&&,||

逻辑操作符(logical operator)。在测试结构中,可以用这两个操作符来进行连接两个逻辑值。||是当测试条件有一个为真时返回0(真),全假为假;&&是当测试条件两个都为真时返回真(0),有假为假。

&

如果命令后面跟上一个&符号,这个命令将会在后台运行。

- 减号

  • 命令或者过滤器的选项标志
COMMAND -[选项列表] 
ls -al
sort -dfu $file
set -- $variable 
if [ $file -ot $file2 ]
then
    echo "$file is older than $file2."
fi
  • 标准输入、标准输出重定向(from/to)
bunzip2 linux-2.6.13.tar.bz2 | tar xvf - 
  将前面解压的数据作为tar的标准输入
 (这里使用一个-表示)

– 双减号

1、表示命令的长选项

    sort --ignore-leading-blanks

2、表示选项的结束

     rm -- -badname  删除名为-badname的文件

3、设置脚本参数

    set -- $variable

= 等于号

1、赋值符号

a=28  (注意没有空格)
echo $a   # 28

2、字符串比较

if [ "$a" = "$`b" ]`   (注意等号两边的空格)

== 双等号

= 的同义词

if [ "$a" == "$b" ]

!= 不等于

if [ "$a" != "$b" ]

+ 加号

1、算术操作符,表示加法;

2、 在正则表达式中,表示的是其前的这个匹配规则匹配最少一次;

3、在命令或过滤器中作为选项标记,在某些命令或者内置命令中使用+来启用某些选项,使用-来禁止;

4、在参数替换(parameter substitution)中,+前缀表示替代值(当变量为空的时候,使用+后面的值)

%

1、数学操作符 表示除法

let "z = 5 % 3"
echo $z  # 2

2、正则表达
一个百分号(%)表示从右边截取最短的匹配
两个百分号表示(%%)表示从右边截取最长的匹配

p=b*9
var="abcd12345abc479"
echo ${var%p}, ${var%%p}
##从右边开始查找(想想从左是那个符号?)
##任何在b和9之间的内容(含)
##第一个是找到最短的符合匹配项
##后一个是找最大符合的匹配项(贪婪匹配?)

~

表示根目录

~+

当前目录

~-

前一个工作目录

=~

正则表达式匹配

var="this is a test message."
[[ "$var" =~ tf*message ]] && echo "Sir. Found that." || echo "Sorry Sir. No match be found."
##你可以修改中间的正则表达式匹配项,正则表达式可以但不一定需要使用双引号括起来

^

  1. 在正则表达式中,作为一行的行首(beginning-of-line)位置标志符;

  2. 在参数替换(Parameter substitution)中,这个用法有两种,一个脱字符({var^}),或两个({var^^}),分别表示第一个字母大写,全部大写的意思(Bash version >=4)。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值