bash here-documents here-string

 

bash有三种输入重定向

  • < : 用于文件
  • << : here-documents
  • <<< : here-strings

 

here-documents:

语法格式:

command <<[-]MARKER
    Here Document
MARKER

 

这个操作符指示bash从标准输入读取输入内容,知道读取到只包含MARKER的行为止

在 here-documents 中,我们选择一个单词作为一个标志。它可以是任何一个单词,比如,MARKER、END 和 EOF 等待,但要选择一个不会在我们的数据集合中出现的单词。在第一个标志(比如,<< MARKER)和第二标志(MARKER)之间的所有行都会被作为命令的标准输入。而且第二个标志(MARKER)必须独占一行。
例如,我们使用 here-documents 将文本传入 tr 命令,然后将文本的内容转换为大写:

 

 重定向操作符“<<”和定界标志符“END”之间的空格分隔是可选的。

在重定向操作符“<<”和定界标志符“END”之间追加减号“-”(即<<-END)将会忽略行首的制表符。

** 注意 **
完结标志符(END)必须写在行首

默认情况下,Bash 替换会在 here-documents 的内容上执行,即 here-documents 内部的变量和命令会被求值或运行。

我们可以使用单引号或双引号扩起定界符来使 Bash 替换失效。

 

 

 

 

 

行首的制表符被忽略了,变量PWD没有被替换

 

 

 

 制表符没有被忽略,变量PWD被替换了

 

其实,here-documents 最常用的功能还是用于向用户显示命令或脚本的用法信息。例如,类似如下所示的函数 usage():

function usage(){
        cat <<-EOF
        Usage: command [-x] [-v] [-z] [files]
        A short explanation of the operation goes here
        It might be a few lines long, but shoudn't be excessive
        EOF
}

usage
~

 

 

 

** 注意 **
如果我们尝试在脚本嵌入一小块多行数据,使用 here-documents 是很有用的。使用 here-documents 嵌入很大的数据块是一个不好的习惯。我们应该保持我们的逻辑(你的代码)与我们的输入(我们的数据)分离,最好是在不同的文件中,除非是输入一个很小的数据集。

here-strings 是 here-documents 的一个变种。它由操作符 “<<<” 和作为标准输入的字符串构成(是被 Shell 作为一个整体来处理的序列),here-strings 是一个用于输入重定向的普通字符串,并不是一个特别的字符串,其语法如下:


command <<< string
tr a-z A-Z <<< "ui op nm"

 

 

str='nm vb op'
tr a-z A-Z <<< $str

 

 

 

 

 

 

posted @ 2020-09-25 18:44  ascertain  阅读(444)  评论(0编辑  收藏  举报