Shell 中的 here 文档详解

我们知道平常在linux命令行的操作都可以放到文件里面,赋予可执行权限后,就可以将这文件变成一个shell脚本。但是如果我们跟有些程序交互时,shell脚本却帮不了我们太多。比如编辑一个文件和操作数据库。编辑一个文件一般用vi,进去后hjkl的aio的操作什么的,脚本怎么执行?mysql登陆输入mysql -u 用户 -p 密码后,就跟mysql进行一串交互,shell怎么执行?Here Document就可以派上用场了。

什么是Here Document

Here Document 是在Linux Shell 中的一种特殊的重定向方式,它的基本的形式如下

cmd << delimiter Here Document Contentdelimiter

它的作用就是将两个 delimiter 之间的内容(Here Document Content 部分) 传递给cmd 作为输入参数。

比如在终端中输入cat << EOF ,系统会提示继续进行输入,输入多行信息再输入EOF,中间输入的信息将会显示在屏幕上。如下:

fish@mangos:~$ cat << EOF> First Line> Second Line> Third Line EOF> EOFFirst LineSecond LineThird Line EOF

注: >这个符号是终端产生的提示输入信息的标识符

这里要注意几点

Here Document 不仅可以在终端上使用,在shell 文件中也可以使用,例如下面的here.sh 文件

cat << EOF > output.shEOF

使用 sh here.sh 运行这个脚本文件,会得到output.sh 这个新文件,里面的内容如下

Here Document的变形

delimiter 与变量

在Here Document 的内容中,不仅可以包括普通的字符,还可以在里面使用变量,例如将上面的here.sh 改为

cat << EOF > output.shEOF

使用sh here.sh HereDocument 运行脚本得到output.sh的内容

HereDocument

在这里 $1 被展开成为了脚本的参数 HereDocument

但是有时候不想展开这个变量怎么办呢,可以通过在起始的 delimiter的前后添加 ” 来实现,例如将上面的here.sh 改为

cat << EOF > output.shEOF

得到的output.sh 的内容为

<< 变为 <<-

Here Document 还有一个用法就是将 ‘<<‘ 变为 ‘<<-‘。 使用 <<- 的唯一变化就是Here Document 的内容部分每行前面的 tab (制表符)将会被删除掉,这种用法是为了编写Here Document的时候可以将内容部分进行缩进,方便阅读代码。

Here Document的两个应用shell编辑文件。

shell编辑文件最常用的方法就是echo 字符串 >> 文件。但是要删除一行怎么办?Here Document就搞定了。在Here Document中使用vi是不行的。替代方法是使用ed命令。在命令行执行以下:

$ touch base.txt $ ed base.txt a this is line1. this is line2. this is line3. this is line4. . wq

先新建一个文件base.txt,,然后ed这个文件,输入a表示最后追加,输入了四行文字。.表示结束输入。wq表示保存退出。

那我们再用ed命令,在shell脚本里面对这个文件再次进行操作。如下。

#!/bin/sh ed base.txt << !ED1_JEREMIAH! 3 d i this is line 3 new. . w q !ED1_JEREMIAH!

解释下:ed base.txt << !ED1_JEREMIAH! 表示编辑base.txt,用变量!ED1_JEREMIAH!标记,这里搞的变量复杂为了和shell中的其他变量进行区分。3表示到第3行,d表示删除,然后i表示本行增加,输入this is line 3 new。其他的同上述。最后用!ED1_JEREMIAH!结束。也就是说两个!ED1_JEREMIAH!之间的每一行都是类似与命令行输入到ed名中,进行交互。

执行的结果如下所示。

$ sh ed_file.sh && cat base.txtline3. line1. this is line2. . this is line4.

关于ed的操作和参数,可以查看linux帮助或去搜索相关的资料。

shell控制数据库

假设执行下面的操作访问数据库。

$ mysql -u root Welcome ; or \g. Your MySQL connection id is 1257 Server version: 5.1.35-community MySQL Community Server (GPL) Type help. Type current input statement. mysql> use mysql Reading table information for completion of table and column names You can turn off this feature quicker startup with -A mysql> select * from user; mysql> exit Bye

如果我们要用shell脚本访问,则可以编写如下的脚本。

#!/bin/sh mysql -u root << !ED2_JEREMIAH! use mysql select * from user; exit !ED2_JEREMIAH!

执行如下。

sh mysql_access.sh

走过一段路,风景毕竟不相同。这段惠风和畅,

Shell 中的 here 文档详解

相关文章:

你感兴趣的文章:

标签云: